[英]Access Using XSLT to import XML
我目前正在开发Access上的新代码,但似乎无法解决。 我是xslt的新手,我了解“ For-Each”的基本概念,但仍然遇到麻烦。 我希望你们中的某些人能帮助我理解为什么我的代码无法正常运行。
我希望将所有这些分支名称都放在单独的行中,以在Access的表中打印所有这些内容。 目前,我将分支名称打印在一行中。
任何帮助。 感谢大伙们!
XSLT代码
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" indent="yes"/>
<xsl:template match="/">
<ING_PNA_Import>
<xsl:for-each select="PNAResponse/PriceAndAvailability">
<Import>
<Test>
<SKU>
<xsl:value-of select="@SKU"/>
</SKU>
<VendorNumber>
<xsl:value-of select="VendorNumber"/>
</VendorNumber>
<Price>
<xsl:value-of select="Price"/>
</Price>
<MPN>
<xsl:value-of select="ManufacturerPartNumber"/>
</MPN>
<ID>
<xsl:value-of select="Branch/@ID"/>
<xsl:text>
</xsl:text>
</ID>
<Name>
<xsl:for-each select="Branch">
<xsl:value-of select="@Name"/>
</xsl:for-each>`
</Name>
<Availability>
<xsl:value-of select="Branch/Availability"/>
</Availability>
</Test>
</Import>
</xsl:for-each>
</ING_PNA_Import>
XML代码:
<?xml version="1.0" encoding="iso-8859-1"?>
<PNAResponse>
<Version>2.0</Version>
<TransactionHeader>
<SenderID>YOU</SenderID>
<ReceiverID>MD</ReceiverID>
<ErrorStatus ErrorNumber=""></ErrorStatus>
<DocumentID></DocumentID>
<TransactionID></TransactionID>
</TransactionHeader>
<PriceAndAvailability SKU="100150" Quantity="1">
<Price>21.21</Price>
<SpecialPriceFlag></SpecialPriceFlag>
<ManufacturerPartNumber>TEST1234</ManufacturerPartNumber>
<ManufacturerPartNumberOccurs></ManufacturerPartNumberOccurs>
<VendorNumber>123X</VendorNumber>
<Description>Cool Item</Description>
<ReserveInventoryFlag>Y</ReserveInventoryFlag>
<AvailableRebQty>0</AvailableRebQty>
<Branch Name="Town1" ID="01">
<Availability>8</Availability>
<OnOrder>0</OnOrder>
<ETADate></ETADate>
</Branch>
<Branch Name="Town2" ID="02">
<Availability>8</Availability>
<OnOrder>0</OnOrder>
<ETADate></ETADate>
</Branch>
<Branch Name="Town3" ID="03">
<Availability>6</Availability>
<OnOrder>5</OnOrder>
<ETADate></ETADate>
</Branch>
<Branch Name="Town4" ID="04">
<Availability>5</Availability>
<OnOrder>5</OnOrder>
<ETADate></ETADate>
</Branch>
<Branch Name="Town5" ID="05">
<Availability>10</Availability>
<OnOrder>0</OnOrder>
<ETADate></ETADate>
</Branch>
<UPC>123456789012345</UPC>
<CustomerPartNumber></CustomerPartNumber>
只需将您的<Name>
节点嵌套在Branch <xsl:for-each>
即可实现多个子节点:
以前
<Name>
<xsl:for-each select="Branch">
<xsl:value-of select="@Name"/>
</xsl:for-each>`
</Name>
更新
<xsl:for-each select="Branch">
<Name>
<xsl:value-of select="@Name"/>
</Name>
</xsl:for-each>
输出量
<?xml version='1.0' encoding='UTF-8'?>
<ING_PNA_Import>
<Import>
<Test>
<SKU>100150</SKU>
<VendorNumber>123X</VendorNumber>
<Price>21.21</Price>
<MPN>TEST1234</MPN>
<ID>01</ID>
<Name>Town1</Name>
<Name>Town2</Name>
<Name>Town3</Name>
<Name>Town4</Name>
<Name>Town5</Name>
<Availability>8</Availability>
</Test>
</Import>
</ING_PNA_Import>
但是,在MS Access中,像大多数数据库一样,您需要使用不同的列名,因此请考虑在数字后缀,即节点的位置:
<xsl:for-each select="Branch">
<xsl:element name="{concat('Name', position())}">
<xsl:value-of select="@Name"/>
</xsl:element>
</xsl:for-each>
输出量
<?xml version='1.0' encoding='UTF-8'?>
<ING_PNA_Import>
<Import>
<Test>
<SKU>100150</SKU>
<VendorNumber>123X</VendorNumber>
<Price>21.21</Price>
<MPN>TEST1234</MPN>
<ID>01</ID>
<Name1>Town1</Name1>
<Name2>Town2</Name2>
<Name3>Town3</Name3>
<Name4>Town4</Name4>
<Name5>Town5</Name5>
<Availability>8</Availability>
</Test>
</Import>
</ING_PNA_Import>
最后,无需<xsl:for-each>
即可完成所有这些操作, <xsl:for-each>
经常由XSLT的新手经常使用,因此习惯于对尚不了解XSLT递归模板映射的通用语言进行的迭代编程。 另外,您的可用性当前仅从第一个分支节点获取。 下面重新创建,但考虑将所有值映射到最后一个模板中的对应Branch :
另类
<?xml version='1.0' encoding='UTF-8'?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="xml" indent="yes"/>
<xsl:template match="/PNAResponse">
<ING_PNA_Import>
<xsl:apply-templates select="PriceAndAvailability"/>
</ING_PNA_Import>
</xsl:template>
<xsl:template match="PriceAndAvailability">
<Import>
<Test>
<SKU><xsl:value-of select="@SKU"/></SKU>
<VendorNumber><xsl:value-of select="VendorNumber"/></VendorNumber>
<Price><xsl:value-of select="Price"/></Price>
<MPN><xsl:value-of select="ManufacturerPartNumber"/></MPN>
<ID><xsl:value-of select="Branch/@ID"/></ID>
<xsl:apply-templates select="Branch"/>
<xsl:copy-of select="Branch[1]/Availability"/>
</Test>
</Import>
</xsl:template>
<xsl:template match="Branch">
<xsl:element name="{concat('Name', position())}">
<xsl:value-of select="@Name"/>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.