Задача муравья выбрать слова из строки - PullRequest
2 голосов
/ 10 марта 2011

Скажем, у меня есть строка - "D: \ ApEx_Schema \ Functions \ new.sql @@ \ main \ ONEVIEW_Integration \ 3" Мне нужно извлечь следующую информацию в переменные diff - имя файла - путь к файлу - и версию (котораяявляется последним символом строки)

Пожалуйста, помогите с помощью задач ANT

===================================== Я пытаюсь прочитать текстовый файл, который содержит данные, указанные ниже: -

.\ApEx_Schema\Functions\new.sql@@\main\ONEVIEW_Integration\3

.\ApEx_Schema\Functions\Functions.sql@@\main\ONEVIEW_Integration\3

.\ApEx_Schema\Indexes\Indexes.sql@@\main\ONEVIEW_Integration\2

и пытаюсь собрать имя файла, его путь и деталии его версия и обновление то же самое в БД с помощью задачи SQL.Хотя мой build.xml не выдает желаемого результата.Любые предложения и мнения !!!

Мой файл Build.xml выглядит как - ============== START ===========================

<description>
    obiee copy files build file
</description>

<replace file="D:\buildFRIDAY\database.txt" token=".\" value="D:\"/>  
<loadfile property="src" srcFile="D:\buildFRIDAY\database.txt"/> 

<path id="antclasspath"> 
    <fileset dir="D:\OraHome_1\oracledi\drivers">     
    <include name="ojdbc14.jar"/>    
    </fileset>  
</path>  

<for list="${src}" param="detls" delimiter="${line.separator}"> 
 <sequential>   
        <taskdef resource="net/sf/antcontrib/antcontrib.properties"/>
        <propertyregex property="path" input="@{detls}"
                       regexp="(.*)\\.*@@" select="\1" />
        <propertyregex property="file" input="@{detls}"
                       regexp=".*\\(.*)@@" select="\1" />
        <propertyregex property="version" input="@{detls}"
                       regexp=".*\\(.*)" select="\1" />

        <echo>
        Input:   @{detls}
        Path:    ${path}
        File:    ${file}
        Version: ${version}
        </echo>

        <if>
                <matches string="@{detls}" pattern=".sql"  /> 
         <then>

         </then>
        </if>

        <if>
                <matches string="@{detls}" pattern="[0-9]"  /> 
     <then>
            <sql     
                driver="oracle.jdbc.driver.OracleDriver"   
                url="jdbc:oracle:thin:@172.16.88.68:1521:rdev"   
                userid="rapid"    
                password="rapid"     
                print="yes"     
                classpathref="antclasspath">     

                Insert into ROLTA_PATCH_FILE_APP_TAB (PATCH_NO,FILE_NAME,FILE_PATH,FILE_VERSION,APPLIED_DATE,STATUS) values ('3.2.12',"@{detls}",'D:\ApEx_Schema\Functions\Functions.sql','3',to_date('11-MAR-11','DD-MON-RR'),'Y');

                Insert into ROLTA_PATCH_TAB (PATCH_NO,PATCH_NAME,APPL_NAME,APPLIED_DATE) values ('3.2.12','2.1.11','@{detls}',to_date('11-MAR-11','DD-MON-RR'));
            </sql>  
         </then>
        </if>
  </sequential> 
</for> 

============== END ===========================

Ответы [ 2 ]

2 голосов
/ 10 марта 2011

Это не то, что хорошо умеет муравей. Вероятно, самое простое решение - использовать ant-contrib propertyregex task :

<taskdef resource="net/sf/antcontrib/antcontrib.properties"/>

<property name="candidate"
          value="D:\ApEx_Schema\Functions\new.sql@@\main\ONEVIEW_Integration\3" />

<propertyregex property="path" input="${candidate}"
               regexp="(.*)\\.*@@" select="\1" />
<propertyregex property="file" input="${candidate}"
               regexp=".*\\(.*)@@" select="\1" />
<propertyregex property="version" input="${candidate}"
               regexp=".*\\(.*)" select="\1" />

<echo>
Input:   ${candidate}
Path:    ${path}
File:    ${file}
Version: ${version}
</echo>

Это включает в себя получение фляги сборника задач ant-contrib.

A - довольно неприятно - альтернатива - использовать scriptdef задание .

<scriptdef name="get_elements" language="javascript">
    <attribute name="candidate" />
    <attribute name="path-property" />
    <attribute name="file-property" />
    <attribute name="version-property" />
    <![CDATA[
        filesep = project.getProperty( "file.separator" );
        candidate = attributes.get( "candidate" );
        path = candidate.substring( 0, candidate.indexOf( "@@" ) );
        file = path.substring( path.lastIndexOf( filesep ) + 1 );
        path = path.substring( 0, path.lastIndexOf( filesep ) );
        version = candidate.substring( candidate.lastIndexOf( filesep )  + 1 );

        project.setProperty( attributes.get( "path-property" ), path );
        project.setProperty( attributes.get( "file-property" ), file );
        project.setProperty( attributes.get( "version-property" ), version );
    ]]>
</scriptdef>

<property name="candidate"
          location="D:\ApEx_Schema\Functions\new.sql@@\main\ONEVIEW_Integration\3"
          relative="yes" />
<get_elements candidate="${candidate}"
              path-property="path"
              file-property="file"
              version-property="version" />
<echo>
Input:   ${candidate}
Path:    ${path}
File:    ${file}
Version: ${version}
</echo>

(Примечание: это проверено на Unix-ОС, поэтому вам может потребоваться настроить обработку разделителя пути, если в Windows.)

Обновление:

Некоторые замечания о вашей реализации.

Возможно, вам потребуется указать пространство имен для задачи:

<ac:for list="${src}" param="detls" delimiter="${line.separator}"
        xmlns:ac="antlib:net.sf.antcontrib">
    ...
</ac:for>

Если вы хотите propertyregex изменить свойство (которое вы делаете во время итерации), вам нужно установить override="yes" на каждом из них. Внутри for вам нужно выбраться по указателям, например:

<propertyregex property="path"
               input="@{detls}"
               regexp="(.*)\\.*\@\@" select="\1"
               override="yes"/>

Для ссылки на свойство, установленное propertyregex, используйте ${path} вместо @{path}.

1 голос
/ 28 апреля 2016

Альтернатива, для которой не требуется заданная задача "propertyregex" или javascript.

<property name="candidate" value="D:\ApEx_Schema\Functions\new.sql@@\main\ONEVIEW_Integration\3" />

<pathconvert property="path">
    <path location="${candidate}" />
    <regexpmapper from="(.*)\\.*@@" to="\1" />
</pathconvert>

<pathconvert property="file">
    <path location="${candidate}" />
    <regexpmapper from=".*\\(.*)@@" to="\1" />
</pathconvert>

<pathconvert property="version">
    <path location="${candidate}" />
    <regexpmapper from=".*\\(.*)" to="\1" />
</pathconvert>

<echo>
Input:   ${candidate}
Path:    ${path}
File:    ${file}
Version: ${version}
</echo> 
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...