セカンダリまたは別のxmlファイルのデータを使用して、以下のXMLの要素を更新しようとしています。入力XMLとセカンダリXMLファイルの両方に同じ数のセグメントがあります。セカンダリXMLの最初のセグメントで値を取得し、INPUTxmlなどの要素を更新する必要があります。XSLを使用して実行できるかどうかはわかりませんが、誰かに案内してもらえますか。
具体的には、セカンダリXMLの// PDetails / PStatus / Codeと// PDetails / PStatus / Descriptionの値に基づいて<indicator></indicator>
それぞれの<iOSection>
INPUTXMLの値を更新しようとしています。
以下はINPUTXMLファイルです。
<IResponse>
<iOSection>
<Details>
<Info>
<pNumber>FB061689</pNumber>
<indicator></indicator>
<Identifier>1</Identifier>
</Info>
</Details>
<Token>
<Reference>1UUYD05BHM21OJCK3881C7F</Reference>
</Token>
</iOSection>
<iOSection>
<Details>
<Info>
<pNumber>FB061690</pNumber>
<indicator></indicator>
<Identifier>2</Identifier>
</Info>
</Details>
<Token>
<Reference>1UUYD05BHM21OJCK3881C7F</Reference>
</Token>
</iOSection>
</IResponse>
以下はセカンダリXMLファイルです-RSPDetailsと呼ばれるxsl変数で利用できます
<RS PartID="abcd" SysID="mnc">
<PDetails>
<PN>FB063586</PN>
<PStatus>
<Code>0</Code>
<Description>Cancelled</Description>
</PStatus>
</PDetails>
<PDetails>
<Error>
<Code>92</Code>
<Message>failed</Message>
</Error>
</PDetails>
</RS>
<indicator>
// PDetails / PStatus / Code = '0'および// PDetails / PStatus / Description = 'Cancelled'の場合、の値は'YES'である必要があり、それ以外の場合は 'NO'である必要があります。
条件は、<iOSection>
位置1の<PDetails>
データを使用して位置1に適用し、位置2のデータ<iOSection>
を使用して<PDetails>
位置2に適用する必要があります。
期待される出力は次のとおりです。
<IResponse>
<iOSection>
<Details>
<Info>
<pNumber>FB061689</pNumber>
<indicator>YES</indicator>
<Identifier>1</Identifier>
</Info>
</Details>
<Token>
<Reference>1UUYD05BHM21OJCK3881C7F</Reference>
</Token>
</iOSection>
<iOSection>
<Details>
<Info>
<pNumber>FB061690</pNumber>
<indicator>NO</indicator>
<Identifier>2</Identifier>
</Info>
</Details>
<Token>
<Reference>1UUYD05BHM21OJCK3881C7F</Reference>
</Token>
</iOSection>
</IResponse>
XSLの下で試しましたが、どこにも近づきませんでした
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:xs="http://www.w3.org/2001/XMLSchema" exclude-result-prefixes="#all" >
<xsl:template match="@* | node()">
<xsl:copy>
<xsl:apply-templates select="@* | node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="/*[local-name()='IResponse']/*[local-name()='iOSection']/*[local-name()='Details']/*[local-name()='Info']/*[local-name()='indicator']">
<xsl:variable name="RSDetails">
<RS PartID="abcd" SysID="mnc">
<PDetails>
<PN>FB063586</PN>
<PStatus>
<Code>0</Code>
<Description>Cancelled</Description>
</PStatus>
</PDetails>
<PDetails>
<Error>
<Code>92</Code>
<Message>failed</Message>
</Error>
</PDetails>
</RS>
</xsl:variable>
<xsl:element name="indicator">
<xsl:variable name="PStatus">
<xsl:value-of select="$RSDetails/RS/PDetails/PStatus" />
</xsl:variable>
<xsl:variable name="Message">
<xsl:value-of select="$RSDetails/RS/PDetails/Message" />
</xsl:variable>
<xsl:choose>
<xsl:when test="$PStatus='0' and $Message='Cancelled'">
<xsl:value-of select="'YES'" />
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="'NO'" />
</xsl:otherwise>
</xsl:choose>
</xsl:element>
<xsl:copy-of select="@*" />
</xsl:template>
</xsl:stylesheet>
ここで実行したいのは、外部ファイル内の一致するノードから値を検索することです。あなたはそうは言わなかったが、一致するノードはPN
値がローカルと一致するノードであると私は推測するpNumber
。
XSLT 1.0
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:param name="RSPDetails" select="document('your_other_file.xml')" />
<xsl:key name="rsp" match="PDetails" use="PN" />
<!-- identity transform -->
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="indicator">
<xsl:copy>
<xsl:variable name="pnum" select="../pNumber"/>
<!-- switch context to the other file -->
<xsl:for-each select="$RSPDetails">
<xsl:choose>
<xsl:when test="key('rsp', $pnum)/PStatus/Code=0 and key('rsp', $pnum)/PStatus/Description='Cancelled'">YES</xsl:when>
<xsl:otherwise>NO</xsl:otherwise>
</xsl:choose>
</xsl:for-each>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
位置に基づいてルックアップを行うには、次のことを試してください。
<xsl:template match="indicator">
<xsl:copy>
<xsl:variable name="i">
<xsl:number count="iOSection"/>
</xsl:variable>
<xsl:variable name="detail" select="$RSPDetails/RS/PDetails[number($i)]"/>
<xsl:choose>
<xsl:when test="$detail/PStatus/Code=0 and $detail/PStatus/Description='Cancelled'">YES</xsl:when>
<xsl:otherwise>NO</xsl:otherwise>
</xsl:choose>
</xsl:copy>
</xsl:template>
<xsl:key>
このシナリオでは、命令は必要ありません。
この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。
侵害の場合は、連絡してください[email protected]
コメントを追加