XSL 1.0 сравнивает и заменяет текст элемента xml из другой строки xml - PullRequest
0 голосов
/ 06 февраля 2019

У меня есть XML-таблица, подобная этой:

<tr>
    <td><font face="Calibri">Tank CIP warning interval (Hours)</font></td>
    <td><font face="Calibri">||MIN_CIP_EXPIRE_TIME||</font></td>
    <td><font face="Calibri">CIP Check - Tank Filter</font></td>
    <td><font face="Calibri">Equipment</font></td>
    <td><font face="Calibri">True</font></td>
</tr>
<tr>
    <td><font face="Calibri">Vent Filter Material ID</font></td>
    <td><font face="Calibri">||MM_EXPECTED_FILTER_MATL_ID_01||</font></td>
    <td><font face="Calibri">Scan/Install/Consume Vent Filters</font></td>
    <td><font face="Calibri">Materials</font></td>
    <td><font face="Calibri">False</font></td>
</tr>

Я должен заменить текст 3-го элемента во всем XML-файле на "Step Reference" из следующей XML-строки путем сравнения TagName.

<Data>
    <row>
        <BoPName>OP_R_CFG_DEFINED_WEIGH_SEQUENCE</BoPName>
        <TagName>||MIN_CIP_EXPIRE_TIME||</TagName>
        <StepReference>Calculate Expiry</StepReference>
    </row>
    <row>
        <BoPName>OP_R_CFG_FIRST_ADD_EXP_INTERVAL</BoPName>
        <TagName>||MM_EXPECTED_FILTER_MATL_ID_01||</TagName>
        <StepReference>Scan Material</StepReference>
   </row>
<Data>

. CIP Check - Резервуарный фильтр должен быть заменен на Рассчитать срок действия .

Пожалуйста, ознакомьтесь с этой картинкой

1 Ответ

0 голосов
/ 06 февраля 2019

Предполагая, что вы хотите xslt 1.0, а не 2.0, тогда что-то вроде

<table>
 <tr>
    <td><font face="Calibri">Tank CIP warning interval (Hours)</font></td>
    <td><font face="Calibri">||MIN_CIP_EXPIRE_TIME||</font></td>
    <td><font face="Calibri">CIP Check - Tank Filter</font></td>
    <td><font face="Calibri">Equipment</font></td>
    <td><font face="Calibri">True</font></td>
</tr>
<tr>
    <td><font face="Calibri">Vent Filter Material ID</font></td>
    <td><font face="Calibri">||MM_EXPECTED_FILTER_MATL_ID_01||</font></td>
    <td><font face="Calibri">Scan/Install/Consume Vent Filters</font></td>
    <td><font face="Calibri">Materials</font></td>
    <td><font face="Calibri">False</font></td>
</tr>
</table>

с файлом данных tab2.xml

<Data>
    <row>
        <BoPName>OP_R_CFG_DEFINED_WEIGH_SEQUENCE</BoPName>
        <TagName>||MIN_CIP_EXPIRE_TIME||</TagName>
        <StepReference>Calculate Expiry</StepReference>
    </row>
    <row>
        <BoPName>OP_R_CFG_FIRST_ADD_EXP_INTERVAL</BoPName>
        <TagName>||MM_EXPECTED_FILTER_MATL_ID_01||</TagName>
        <StepReference>Scan Material</StepReference>
   </row>
</Data>

Вы можете создать поиск ключа, например

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

 <xsl:variable name="data" select="document('tab2.xml')"/>

 <xsl:key name="k" match="StepReference" use="../TagName"/>

 <xsl:template match="node()">
  <xsl:copy>
   <xsl:copy-of select="@*"/>
   <xsl:apply-templates/>
  </xsl:copy>
 </xsl:template>


 <xsl:template match="td/font/text()">
  <xsl:variable name="here" select="."/>
  <xsl:variable name="tn" select="../../preceding-sibling::*[1]/font"/>
  <xsl:for-each select="$data">
   <xsl:choose>
    <xsl:when test="key('k',$tn)">
     <xsl:value-of select="key('k',$tn)"/>
    </xsl:when>
    <xsl:otherwise>
     <xsl:value-of select="$here"/>
    </xsl:otherwise>
   </xsl:choose>
  </xsl:for-each>
 </xsl:template>


</xsl:stylesheet>

Производство:

$ xsltproc tab.xsl tab.xml
<?xml version="1.0"?>
<table>
 <tr>
    <td><font face="Calibri">Tank CIP warning interval (Hours)</font></td>
    <td><font face="Calibri">||MIN_CIP_EXPIRE_TIME||</font></td>
    <td><font face="Calibri">Calculate Expiry</font></td>
    <td><font face="Calibri">Equipment</font></td>
    <td><font face="Calibri">True</font></td>
</tr>
<tr>
    <td><font face="Calibri">Vent Filter Material ID</font></td>
    <td><font face="Calibri">||MM_EXPECTED_FILTER_MATL_ID_01||</font></td>
    <td><font face="Calibri">Scan Material</font></td>
    <td><font face="Calibri">Materials</font></td>
    <td><font face="Calibri">False</font></td>
</tr>
</table>
...