请帮帮我......
我输入了XML文档:
<?xml version="1.0" encoding="utf-8"?>
<Root>
<Object>
<GUID>201110180954525010129</GUID>
<Meta name="FILENAME" format="string" frate="" />
</Object>
</Root>
我需要将它转换为下一个xml:
<?xml version="1.0" encoding="UTF-8"?>
<Root>
<Object>
<GUID>201110180954525010129</GUID>
<FILENAME/>
</Object>
<Root>
我创建了下一个样式表:
<?xml version="1.0" encoding="utf-8"?>
<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:template match="/">
<xsl:element name="Root">
<xsl:for-each select="Root/Object">
<xsl:element name="Object">
<xsl:element name="FILENAME">
<xsl:value-of select="Meta[@name='FILENAME']" />
</xsl:element>
<xsl:element name="GUID">
<xsl:value-of select="GUID" />
</xsl:element>
</xsl:element>
</xsl:for-each>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
但是当我试图改变它时,我得到了下一个结果:
<?xml version="1.0" encoding="UTF-8"?>
<Root>
<Object>
<GUID>201110180954525010129</GUID>
<FILENAME> </FILENAME>
</MAObject>
<Root>
如何解释自闭标签?
C#转换代码:
var stylesheet = "styleSheet.xml";
XmlDocument xmlDocument = new XmlDocument();
xmlDocument.Load("input.xml");
XslCompiledTransform xslTransform = new XslCompiledTransform();
xslTransform.Load(styleSheet);
XmlDocument xmlDocumentOutput = new XmlDocument();
XmlDeclaration xmlDocumentOutputDeclaration = xmlDocumentOutput.CreateXmlDeclaration("1.0", "utf-8", null);
xmlDocumentOutput.AppendChild(xmlDocumentOutputDeclaration);
using (XmlWriter xmlWriter = xmlDocumentOutput.CreateNavigator().AppendChild())
{
xslTransform.Transform(xmlDocument.CreateNavigator(), null, xmlWriter);
}
return xmlDocumentOutput;
答案 0 :(得分:0)
我用XslCompiledTransform尝试了我的样本,我得到的输出是
<Root>
<Object>
<FILENAME></FILENAME>
<GUID>201110180954525010129</GUID>
</Object>
</Root>
如何准确地运行转换,您如何看待输出?
使用XML,空的“foo”元素可以标记为<foo></foo>
或<foo/>
或<foo />
,这些形式在语义上是等效的。你为什么需要特定的表格? XSLT转换的输出是否未由XML解析器处理?
[edit]尝试更换
<xsl:element name="FILENAME">
<xsl:value-of select="Meta[@name='FILENAME']" />
</xsl:element>
与
<FILENAME>
<xsl:if test="normalize-space(Meta[@name='FILENAME'])">
<xsl:value-of select="Meta[@name='FILENAME']"/>
</xsl:if>
</FILENAME>
至少确保您获得的FILENAME元素为空。
答案 1 :(得分:0)
尝试删除与<xsl:value-of>
匹配的模板中FILENAME
周围的换行符(以及任何其他空格)。它们是显示在结果中的文本节点。
答案 2 :(得分:0)
我不知道它是否会有任何区别,但请尝试使用此样式表,该样式表具有 Meta 的单独匹配模板,包含和不包含数据。如果没有别的,它建立在身份模板上,因此无需在原始XSLT中对如此多的元素名称进行硬编码
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" indent="yes"/>
<xsl:template match="Meta">
<xsl:element name="{@name}" />
</xsl:template>
<xsl:template match="Meta[. != '']">
<xsl:element name="{@name}">
<xsl:apply-templates select="node()"/>
</xsl:element>
</xsl:template>
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
当我测试时,我得到以下结果:
<Root>
<Object>
<GUID>201110180954525010129</GUID>
<FILENAME/>
</Object>
</Root>