【发布时间】:2021-05-20 22:05:02
【问题描述】:
我有这个 xml:
<?xml version="1.0" encoding="utf-8"?>
<Document Id="0c744468-67d8-4daa-8ff9-cbd23209c59d" Name="ROW_Easement (1)" TypeId="adde4dc1-0710-452a-82c7-9e5ac1bafe94" TypeName="ROW_Easement" OriginalName="106-19-47A.pdf" MimeType="application/pdf">
<Field Name="File Name" Confidence="1.00" Page="1" Valid="True">106-19-47A</Field>
<Section Name="tblPersonOfInterest">
<SectionCollection Name="From" Count="4">
<Section Name="From 1">
<Field Name="Grantor" Confidence="1.00" Page="1" Valid="True" Location="1.713, 8.200, 6.487, 0.500">MARY E. GIBSON, and husband, E. J. GIBSON;
ROSALIE L. SIEN, and husband, A. C. SIEN, Jr</Field>
</Section>
</SectionCollection>
</Section>
</Document>
我想用“名称”属性值替换所有节点名称。到目前为止,我有:
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="3.0">
<xsl:output method="xml" indent="yes" />
<xsl:template match="@*|node()">
<ROW_Easement>
<xsl:for-each select="Field">
<xsl:element name="{translate(@Name, ' ', '_')}">
<xsl:value-of select="self::node()" />
</xsl:element>
</xsl:for-each>
<xsl:for-each select="Section">
<xsl:element name="{translate(@Name, ' ', '_')}">
<xsl:value-of select="self::node()" />
</xsl:element>
</xsl:for-each>
<xsl:for-each select="SectionCollection">
<xsl:element name="{translate(@Name, ' ', '_')}">
<xsl:value-of select="self::node()" />
</xsl:element>
</xsl:for-each>
</ROW_Easement>
</xsl:template>
</xsl:stylesheet>
结果是:
<?xml version="1.0" encoding="utf-8"?>
<ROW_Easement>
<File_Name>106-19-47A</File_Name>
<tblPersonOfInterest>
MARY E. GIBSON, and husband, E. J. GIBSON;
ROSALIE L. SIEN, and husband, A. C. SIEN, Jr
</tblPersonOfInterest>
</ROW_Easement>
它在 SectionCollection 节点处中断,但我不明白为什么。
根据@michael.hor257k 的建议进行了更新 更新:使用我现在得到的第一个建议:
<?xml version="1.0" encoding="utf-8"?><ROW_Easement>0c744468-67d8-4daa-8ff9-cbd23209c59dROW_Easement (1)adde4dc1-0710-452a-82c7-9e5ac1bafe94ROW_Easement106-19-47A.pdfapplication/pdf
<File_Name>1.001True106-19-47A</File_Name>
<tblPersonOfInterest>
<From>4
<From_1>
<Grantor>1.001True1.713, 8.200, 6.487, 0.500MARY E. GIBSON, and husband, E. J. GIBSON;
ROSALIE L. SIEN, and husband, A. C. SIEN, Jr</Grantor>
</From_1>
</From>
</tblPersonOfInterest>
</ROW_Easement>
【问题讨论】:
-
请发布minimal reproducible example,包括完整的 XML 输入示例和预期输出。
标签: xml xslt nodes transform rename