我有以下以属性为中心的XML格式:
<?xml version="1.0" encoding="UTF-8"?>
<LaborTaskInterface>
<LaborTask thing1="a" thing2="b" thing3="c" thing4="d" thing5="e"
thing6="f" thing7="g" thing8="h" thing9="i">
<ltOverride unit_id="1" value="1" thing2="b" thing3="c" thing4="d"/>
<ltOverride unit_id="2" value="1" thing2="b" thing3="c" thing4="d"/>
<ltOverride unit_id="3" value="1" thing2="b" thing3="c" thing4="d"/>
<ltOverride unit_id="4" value="1" thing2="b" thing3="c" thing4="d"/>
</LaborTask>
</LaborTaskInterface>
我已经将其转换为以元素为中心的XML格式:
<?xml version="1.0" encoding="UTF-8"?>
<LaborTaskInterface>
<LaborTask>
<thing1>a</thing1>
<thing2>b</thing2>
<thing3>c</thing3>
<thing4>d</thing4>
<thing5>e</thing5>
<thing6>f</thing6>
<thing7>g</thing7>
<thing8>h</thing8>
<thing9>i</thing9>
<ltOverride>
<unit_id>1</unit_id>
<value>1</value>
<thing2>b</thing2>
<thing3>c</thing3>
<thing4>d</thing4>
</ltOverride>
<ltOverride>
<unit_id>2</unit_id>
<value>10</value>
<thing2>b</thing2>
<thing3>c</thing3>
<thing4>d</thing4>
</ltOverride>
<ltOverride>
<unit_id>3</unit_id>
<value>100</value>
<thing2>b</thing2>
<thing3>c</thing3>
<thing4>d</thing4>
</ltOverride>
<ltOverride>
<unit_id>4</unit_id>
<value>1000</value>
<thing2>b</thing2>
<thing3>c</thing3>
<thing4>d</thing4>
</ltOverride>
</LaborTask>
</LaborTaskInterface>
使用此XSL转换:
<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:stylesheet>
然而,我遇到的问题是,当导入到Microsoft Access时(因为Access只接受以元素为中心(,它想要创建两个单独的表——LaborTask和ItOverride。
我希望所有的信息都放在一张桌子上。这意味着整个LaborTask将随着每次ItOverride的出现而重复(这是我们的愿望,所以这是完全可以接受的(。
这就是最终的格式:
<?xml version="1.0" encoding="UTF-8"?>
<LaborTaskInterface>
<ltOverride>
<unit_id>1</unit_id>
<value>1</value>
<thing1>a</thing1>
<thing2>b</thing2>
<thing3>c</thing3>
<thing4>d</thing4>
<thing5>e</thing5>
<thing6>f</thing6>
<thing7>g</thing7>
<thing8>h</thing8>
<thing9>i</thing9>
</ltOverride>
<ltOverride>
<unit_id>2</unit_id>
<value>10</value>
<thing2>b</thing2>
<thing3>c</thing3>
<thing4>d</thing4>
<thing5>e</thing5>
<thing6>f</thing6>
<thing7>g</thing7>
<thing8>h</thing8>
<thing9>i</thing9>
</ltOverride>
<ltOverride>
<unit_id>3</unit_id>
<value>100</value>
<thing2>b</thing2>
<thing3>c</thing3>
<thing4>d</thing4>
<thing5>e</thing5>
<thing6>f</thing6>
<thing7>g</thing7>
<thing8>h</thing8>
<thing9>i</thing9>
</ltOverride>
<ltOverride>
<unit_id>4</unit_id>
<value>1000</value>
<thing2>b</thing2>
<thing3>c</thing3>
<thing4>d</thing4>
<thing5>e</thing5>
<thing6>f</thing6>
<thing7>g</thing7>
<thing8>h</thing8>
<thing9>i</thing9>
</ltOverride>
</LaborTaskInterface>
我对如何进入最终格式一无所知,这让我想到了我的问题。。。我怎么去那里?我的XSLT应该是什么样子?
一个ItOverride中而非另一个ItOverride中的节点示例:
<?xml version="1.0" encoding="UTF-8"?>
<LaborTaskInterface>
<ltOverride>
<unit_id>1573</unit_id>
<thing1>7.000</thing1>
<thing2>1.000</thing2>
<thing3></thing3>
<thing4></thing4>
<thing5></thing5>
<value>13.7097</value>
<thing6>Minutes</thing6>
<thing7>7.000</thing7>
<thing8>1.000</thing8>
<thing9>xxx</thing9>
<thing10>n</thing10>
<thing11>yyy</thing11>
<thing12>756</thing12>
<thing13>d</thing13>
<thing14>Minutes</thing14>
<thing15></thing15>
<thing16></thing16>
<thing17></thing17>
</ltOverride>
<ltOverride>
<unit_id>1573</unit_id>
<thing1>7.000</thing1>
<thing2>1.000</thing2>
<thing3></thing3>
<thing4></thing4>
<thing5></thing5>
<value>13.7097</value>
<thing6>Minutes</thing6>
<thing7>7.000</thing7>
<thing8>1.000</thing8>
<thing9>xxx</thing9>
<thing10>n</thing10>
<thing11>yyy</thing11>
<thing12>756</thing12>
<thing13>d</thing13>
<thing14>Minutes</thing14>
<thing15>bb</thing15>
<thing16></thing16>
<thing17>eee</thing17>
</ltOverride>
<ltOverride>
<unit_id>1573</unit_id>
<thing1>7.000</thing1>
<thing2>1.000</thing2>
<thing3></thing3>
<thing4></thing4>
<thing5></thing5>
<value>13.7097</value>
<thing6>Minutes</thing6>
<thing7>7.000</thing7>
<thing8>1.000</thing8>
<thing9>xxx</thing9>
<thing10>n</thing10>
<thing11>yyy</thing11>
<thing12>756</thing12>
<thing13>d</thing13>
<thing14>Minutes</thing14>
<thing15>aaa</thing15>
<thing16>bbb</thing16>
<thing17>c</thing17>
</ltOverride>
</LaborTaskInterface>
到目前为止,基本XML的更新取得了进展。
请参阅基本XML:
<?xml version="1.0" encoding="UTF-8"?>
<LaborTaskInterface>
<LaborTask thing1="a" thing2="c" thing3="d" thing4="e" thing5="f"
thing6="g" thing7="h" thing8="i" thing9="j">
<ltOverride unit_id="1" value="1" thing2="k" thing3="c" thing4="d" thing10="o"/>
<ltOverride unit_id="2" value="1" thing2="l" thing3="c" thing4="d" thing11="p"/>
<ltOverride unit_id="3" value="1" thing2="m" thing3="c" thing4="d" thing12="q"/>
<ltOverride unit_id="4" value="1" thing2="n" thing3="c" thing4="d" thing13="r"/>
</LaborTask>
</LaborTaskInterface>
期望的最终结果:
<?xml version="1.0" encoding="UTF-8"?>
<LaborTaskInterface>
<ltOverride>
<unit_id>1</unit_id>
<value>1</value>
<thing1>a</thing1>
<thing2>c</thing2>
<thing2[2]>k</thing2[2]>
<thing3>c</thing3>
<thing4>d</thing4>
<thing5>f</thing5>
<thing6>g</thing6>
<thing7>h</thing7>
<thing8>i</thing8>
<thing9>j</thing9>
<thing10>o</thing10>
<thing11></thing11>
<thing12></thing12>
<thing13></thing13>
</ltOverride>
<ltOverride>
<unit_id>2</unit_id>
<value>1</value>
<thing1>a</thing1>
<thing2>c</thing2>
<thing2[2]>l</thing2[2]>
<thing3>c</thing3>
<thing4>d</thing4>
<thing5>f</thing5>
<thing6>g</thing6>
<thing7>h</thing7>
<thing8>i</thing8>
<thing9>j</thing9>
<thing10></thing10>
<thing11>p</thing11>
<thing12></thing12>
<thing13></thing13>
</ltOverride>
<ltOverride>
<unit_id>3</unit_id>
<value>1</value>
<thing1>a</thing1>
<thing2>c</thing2>
<thing2[2]>m</thing2[2]>
<thing3>c</thing3>
<thing4>d</thing4>
<thing5>f</thing5>
<thing6>g</thing6>
<thing7>h</thing7>
<thing8>i</thing8>
<thing9>j</thing9>
<thing10></thing10>
<thing11></thing11>
<thing12>q</thing12>
<thing13></thing13>
</ltOverride>
<ltOverride>
<unit_id>4</unit_id>
<value>1</value>
<thing1>a</thing1>
<thing2>c</thing2>
<thing2[2]>n</thing2[2]>
<thing3>c</thing3>
<thing4>d</thing4>
<thing5>f</thing5>
<thing6>g</thing6>
<thing7>h</thing7>
<thing8>i</thing8>
<thing9>j</thing9>
<thing10></thing10>
<thing11></thing11>
<thing12>r</thing12>
<thing13></thing13>
</ltOverride>
</LaborTaskInterface>
Expa
我已经应用了这个XSLT(谢谢Michael.hor257k(:
<xsl:stylesheet version="2.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:template match="/LaborTaskInterface" >
<xsl:copy>
<xsl:for-each select="LaborTask/ltOverride">
<xsl:variable name="temp">
<dummy>
<xsl:copy-of select="../@*"/>
<xsl:copy-of select="@*"/>
</dummy>
</xsl:variable>
<xsl:copy>
<xsl:for-each select="$temp/dummy/@*">
<xsl:element name="{name()}">
<xsl:value-of select="." />
</xsl:element>
</xsl:for-each>
</xsl:copy>
</xsl:for-each>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
它让我得到了这个非常接近的结果:
<?xml version="1.0" encoding="UTF-8"?>
<LaborTaskInterface>
<ltOverride>
<thing1>a</thing1>
<thing2>k</thing2>
<thing3>c</thing3>
<thing4>d</thing4>
<thing5>f</thing5>
<thing6>g</thing6>
<thing7>h</thing7>
<thing8>i</thing8>
<thing9>j</thing9>
<thing10>o</thing10>
<unit_id>1</unit_id>
<value>1</value>
</ltOverride>
<ltOverride>
<thing1>a</thing1>
<thing2>l</thing2>
<thing3>c</thing3>
<thing4>d</thing4>
<thing5>f</thing5>
<thing6>g</thing6>
<thing7>h</thing7>
<thing8>i</thing8>
<thing9>j</thing9>
<thing11>p</thing11>
<unit_id>2</unit_id>
<value>1</value>
</ltOverride>
<ltOverride>
<thing1>a</thing1>
<thing2>m</thing2>
<thing3>c</thing3>
<thing4>d</thing4>
<thing5>f</thing5>
<thing6>g</thing6>
<thing7>h</thing7>
<thing8>i</thing8>
<thing9>j</thing9>
<thing12>q</thing12>
<unit_id>3</unit_id>
<value>1</value>
</ltOverride>
<ltOverride>
<thing1>a</thing1>
<thing2>n</thing2>
<thing3>c</thing3>
<thing4>d</thing4>
<thing5>f</thing5>
<thing6>g</thing6>
<thing7>h</thing7>
<thing8>i</thing8>
<thing9>j</thing9>
<thing13>r</thing13>
<unit_id>4</unit_id>
<value>1</value>
</ltOverride>
</LaborTaskInterface>
非常感谢您的帮助!
谢谢!
考虑以下示例:
XML
<LaborTaskInterface>
<LaborTask thing1="1" thing2="2" thing3="3" thing4="4" thing5="5"
thing6="6" thing7="7" thing8="8" thing9="9">
<ltOverride unit_id="1" value="a" thing2="102" thing3="103" thing4="104"/>
<ltOverride unit_id="2" value="b" thing2="202" thing3="203" thing4="204"/>
<ltOverride unit_id="3" value="c" thing2="302" thing3="303" thing4="304"/>
<ltOverride unit_id="4" value="d" thing2="402" thing3="403" thing4="404"/>
</LaborTask>
</LaborTaskInterface>
XSLT 2.0
<xsl:stylesheet version="2.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:template match="/LaborTaskInterface" >
<xsl:copy>
<xsl:for-each select="LaborTask/ltOverride">
<xsl:copy>
<xsl:for-each select="@unit_id, @value, ../@thing1, @thing2, @thing3, @thing4, ../(@thing5, @thing6, @thing7, @thing8, thing9)">
<xsl:element name="{name()}">
<xsl:value-of select="." />
</xsl:element>
</xsl:for-each>
</xsl:copy>
</xsl:for-each>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
结果
<?xml version="1.0" encoding="UTF-8"?>
<LaborTaskInterface>
<ltOverride>
<unit_id>1</unit_id>
<value>a</value>
<thing1>1</thing1>
<thing2>102</thing2>
<thing3>103</thing3>
<thing4>104</thing4>
<thing5>5</thing5>
<thing6>6</thing6>
<thing7>7</thing7>
<thing8>8</thing8>
</ltOverride>
<ltOverride>
<unit_id>2</unit_id>
<value>b</value>
<thing1>1</thing1>
<thing2>202</thing2>
<thing3>203</thing3>
<thing4>204</thing4>
<thing5>5</thing5>
<thing6>6</thing6>
<thing7>7</thing7>
<thing8>8</thing8>
</ltOverride>
<ltOverride>
<unit_id>3</unit_id>
<value>c</value>
<thing1>1</thing1>
<thing2>302</thing2>
<thing3>303</thing3>
<thing4>304</thing4>
<thing5>5</thing5>
<thing6>6</thing6>
<thing7>7</thing7>
<thing8>8</thing8>
</ltOverride>
<ltOverride>
<unit_id>4</unit_id>
<value>d</value>
<thing1>1</thing1>
<thing2>402</thing2>
<thing3>403</thing3>
<thing4>404</thing4>
<thing5>5</thing5>
<thing6>6</thing6>
<thing7>7</thing7>
<thing8>8</thing8>
</ltOverride>
</LaborTaskInterface>
这是另一种不需要对属性名称进行硬编码的方法。它只是允许子ltOverride
元素的属性覆盖父LaborTask
的类似命名的属性。之后,剩余的属性将转换为元素。
XSLT 2.0
<xsl:stylesheet version="2.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:template match="/LaborTaskInterface" >
<xsl:copy>
<xsl:for-each select="LaborTask/ltOverride">
<xsl:variable name="temp">
<dummy>
<xsl:copy-of select="../@*"/>
<xsl:copy-of select="@*"/>
</dummy>
</xsl:variable>
<xsl:copy>
<xsl:for-each select="$temp/dummy/@*">
<xsl:element name="{name()}">
<xsl:value-of select="." />
</xsl:element>
</xsl:for-each>
</xsl:copy>
</xsl:for-each>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>