我根本不熟悉 XML/XSLT。我只是想学习足够的知识来将此 XML 文件转换为我的 Access 数据库可以使用的东西。XML 数据以属性格式输出,Access 只喜欢元素格式。我已经完成了基本的转换,但我似乎无法对嵌套数据进行元素化。
我希望最终结果是所有元素。目前我的 XSLT 脚本正在尝试在子元素的名称中包含 parental name 属性,但这可能不是必需的。如果我可以在列表元素的名称中编号,那就太棒了。如“AuthorList1”、“AuthorList2”或“Author1”、“Author2”。
这是我正在处理的 XML 类型(缩写):
XML
<Result>
<DocSum>
<Id>25587056</Id>
<Item Name="PubDate" Type="Date">2015 Jan 13</Item>
<Item Name="EPubDate" Type="Date">2015 Jan 13</Item>
<Item Name="Source" Type="String">Invest Ophthalmol Vis Sci</Item>
<Item Name="AuthorList" Type="List">
<Item Name="Author" Type="String">Wang Q</Item>
<Item Name="Author" Type="String">Tuten WS</Item>
<Item Name="Author" Type="String">Lujan BJ</Item>
</Item>
<Item Name="Title" Type="String">Adaptive optics microperimetry</Item>
<Item Name="Volume" Type="String">56</Item>
<Item Name="ArticleIds" Type="List">
<Item Name="pubmed" Type="String">25587056</Item>
<Item Name="pii" Type="String">iovs.14-15576</Item>
<Item Name="doi" Type="String">10.1167/iovs.14-15576</Item>
</Item>
<Item Name="References" Type="List"></Item>
<Item Name="HasAbstract" Type="Integer">1</Item>
</DocSum>
</Result
我在 XSLT 方面已经取得了相当大的进展,但我还没有走到那一步。不断出现的一个问题是空元素(如引用)获得不允许的空名称。当我尝试使用“Item[@Type='List']”的匹配模式执行命令时,就会发生这种情况。此外,我似乎无法让列表的子节点(元素?)成为他们自己的元素。
XSLT
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="xml" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="@*" >
<xsl:element name="{name()}">
<xsl:value-of select="."/>
</xsl:element>
</xsl:template>
<xsl:template match="node()">
<xsl:copy>
<xsl:apply-templates select="@* | node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="Item">
<xsl:element name="{@Name}">
<xsl:value-of select="."/>
</xsl:element>
</xsl:template>
<xsl:template match="child::Item">
<xsl:variable name="Parent" select="TEST"/>
<xsl:element name="{$Parent}{@Name}">
<xsl:value-of select="."/>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
我希望这有某种意义。我真的不想成为这方面的专家,因为我怀疑我是否会在很长一段时间内再次处理 XML 转换。我将不胜感激即将到来的任何帮助。