我正在尝试使用XSL样式表转换XML字符串。但出于某种原因,他只接受我的根元素,而不是其余部分。有点狡猾的摇摆不定的wimey probs,但我看不出这个问题..
我会在下面附上我的代码。
XSL
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:ns0="http://foo.com/foo" xmlns:ns1="http://foo.com/foo" exclude-result-prefixes="ns1">
<xsl:template match="/">
<ns0:ProductionOrderRequests>
<xsl:apply-templates select="ns1:ProductionOrderRequest" />
</ns0:ProductionOrderRequests>
</xsl:template>
<xsl:template match="ns1:ProductionOrderRequest">
<xsl:apply-templates select="ns1:ProductionOrderRequest" />
</xsl:template>
<xsl:template match="ns1:ProductionOrderRequest">
<ProductionOrderRequest>
<MESKey><xsl:value-of select="@MESKey" /></MESKey>
<Material><xsl:value-of select="@Material" /></Material>
<ProductionVersion><xsl:value-of select="@ProductionVersion" /></ProductionVersion>
<Resource><xsl:value-of select="@Resource" /></Resource>
<Plant><xsl:value-of select="@Plant" /></Plant>
<OrderType><xsl:value-of select="@OrderType" /></OrderType>
<StartDate><xsl:value-of select="@StartDate" /></StartDate>
<StartTime><xsl:value-of select="@StartTime" /></StartTime>
<EndDate></EndDate>
<EndTime></EndTime>
<TotalOrderQty><xsl:value-of select="@TotalOrderQty" /></TotalOrderQty>
</ProductionOrderRequest>
</xsl:template>
</xsl:stylesheet>
要转换的XML
<?xml version="1.0" encoding="utf-8"?>
<ProductionOrderRequests xmlns:ns0="http://foo.com/foo">
<ProductionOrderRequest>
<MESKey>TblDatProduction_4017</MESKey>
<Material>11596</Material>
<ProductionVersion>0001</ProductionVersion>
<Resource>60200001</Resource>
<Plant>BE01</Plant>
<OrderType>ZP76</OrderType>
<StartDate>24-10-2008</StartDate>
<StartTime>06:00:00</StartTime>
<EndDate></EndDate>
<EndTime></EndTime>
<TotalOrderQty>1.00</TotalOrderQty>
</ProductionOrderRequest>
</ProductionOrderRequests>
表示xml字符串的C#类。
[XmlRoot("ProductionOrderRequests", Namespace = "http://foo.com/foo")]
public class ProductionOrderRequests
{
[XmlElement("ProductionOrderRequest")]
public List<ProductionOrderRequest> ProductionOrderRequestCollection { get; set; }
}
[XmlRoot("ProductionOrderRequest")]
public class ProductionOrderRequest
{
[XmlElement("MESKey")]
public string MESKey { get; set; }
[XmlElement("Material")]
public int Material { get; set; }
[XmlElement("ProductionVersion")]
public string ProductionVersion { get; set; }
[XmlElement("Resource")]
public int Resource { get; set; }
[XmlElement("Plant")]
public string Plant { get; set; }
[XmlElement("OrderType")]
public string OrderType { get; set; }
[XmlElement("StartDate")]
public string StartDate { get; set; }
[XmlElement("StartTime")]
public string StartTime { get; set; }
[XmlElement("EndDate")]
public string EndDate { get; set; }
[XmlElement("EndTime")]
public string EndTime { get; set; }
[XmlElement("TotalOrderQty")]
public string TotalOrderQty { get; set; }
}
预先形成转换的函数
public static string Transform(this string xmlString, string xslpath)
{
string output = String.Empty;
try
{
StringReader rdr = new StringReader(xmlString);
XPathDocument myXPathDoc = new XPathDocument(rdr);
var myXslTrans = new XslCompiledTransform();
myXslTrans.Load(xslpath);
StringWriter sw = new StringWriter();
XmlWriter xwo = XmlWriter.Create(sw);
myXslTrans.Transform(myXPathDoc, null, xwo);
output = sw.ToString();
xwo.Close();
}
catch (Exception e)
{
Console.WriteLine("Exception: {0}", e.ToString());
}
return output;
}
我尝试了什么
答案 0 :(得分:5)
您的XSLT遇到了一些问题,但首先,您的XML也可能存在问题。它就这样开始......
<ProductionOrderRequests xmlns:ns0="http://foo.com/foo">
您已声明了一个名称空间,但实际上并未在任何地方使用该前缀,这意味着 ProductionOrderRequests ,而所有其他元素都没有名称空间。由于您的XSLT正在寻找命名空间中的元素,因此它们不匹配。可能你的意思是在XML中这样做....
<ProductionOrderRequests xmlns="http://foo.com/foo">
(如果没有,那么您的XSLT中不需要相应的名称空间前缀。)
至于XSLT,你可以从这开始......
<xsl:template match="/">
<ns0:ProductionOrderRequests>
<xsl:apply-templates select="ns1:ProductionOrderRequest" />
</ns0:ProductionOrderRequests>
</xsl:template>
但是"/"
与文档节点匹配,而不是根 ProductionOrderRequests 元素,因此在<xsl:apply-templates select="ns1:ProductionOrderRequest" />
您无法找到任何内容,因为 ProductionOrderRequests 是这种情况下的子节点。它可能需要这个....
<xsl:template match="/">
<ns0:ProductionOrderRequests>
<xsl:apply-templates select="ns1:ProductionOrderRequests" />
</ns0:ProductionOrderRequests>
</xsl:template>
然后你有这个模板......
<xsl:template match="ns1:ProductionOrderRequest">
<xsl:apply-templates select="ns1:ProductionOrderRequest" />
</xsl:template>
您正在匹配 ProductionOrderRequest ,但之后正在寻找同名的孩子。您可能意味着要跳过父 ProductionOrderRequests 元素。
<xsl:template match="ns1:ProductionOrderRequests">
<xsl:apply-templates select="ns1:ProductionOrderRequest" />
</xsl:template>
最后,您正在输出数据......
<MESKey><xsl:value-of select="@MESKey" /></MESKey>
但'@'前缀用于属性。您的XML包含元素,因此它应该是......
<MESKey><xsl:value-of select="ns1:MESKey" /></MESKey>
试试这个XSLT
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:ns0="http://foo.com/foo" xmlns:ns1="http://foo.com/foo" exclude-result-prefixes="ns1">
<xsl:template match="/">
<ns0:ProductionOrderRequests>
<xsl:apply-templates select="ns1:ProductionOrderRequests" />
</ns0:ProductionOrderRequests>
</xsl:template>
<xsl:template match="ns1:ProductionOrderRequests">
<xsl:apply-templates select="ns1:ProductionOrderRequest" />
</xsl:template>
<xsl:template match="ns1:ProductionOrderRequest">
<ProductionOrderRequest>
<MESKey><xsl:value-of select="ns1:MESKey" /></MESKey>
<Material><xsl:value-of select="ns1:Material" /></Material>
<ProductionVersion><xsl:value-of select="ns1:ProductionVersion" /></ProductionVersion>
<Resource><xsl:value-of select="ns1:Resource" /></Resource>
<Plant><xsl:value-of select="ns1:Plant" /></Plant>
<OrderType><xsl:value-of select="ns1:OrderType" /></OrderType>
<StartDate><xsl:value-of select="ns1:StartDate" /></StartDate>
<StartTime><xsl:value-of select="ns1:StartTime" /></StartTime>
<EndDate></EndDate>
<EndTime></EndTime>
<TotalOrderQty><xsl:value-of select="ns1:TotalOrderQty" /></TotalOrderQty>
</ProductionOrderRequest>
</xsl:template>
</xsl:stylesheet>