使用基于XSD的XSLT将XML转换为XML

时间:2011-10-14 19:13:24

标签: xml xslt xsd xalan

我正在使用XSLT / Xalan将一个XML文件转换为另一个XML文件。在这样做的过程中,我发现当我创建XSLT样式表时,我正在硬编码我想要生成的目标文件的节点。这看起来很奇怪。

无论如何使用XSD以编程方式生成目标文件?我想基本上使用我拥有的XSD创建文件的骨架,然后针对源文件运行我的样式表。然后,我可以将我从那里找到的值插入到生成文件中的适当位置。

有没有办法做到这一点?或者XQuery可能会提供这样的功能吗?

2 个答案:

答案 0 :(得分:1)

听起来你问的是如何序列化DataSet并使用XSLT对其进行转换。如果是这样,您可以采用以下方式:

将数据集序列化为XML

DataTable table = new DataTable();     
System.IO.StringWriter writer = new System.IO.StringWriter(); 

//notice that we're ignoring the schema so we get clean XML back 
//you can change the write mode as needed to get your result 
table.WriteXml(writer, XmlWriteMode.IgnoreSchema, false); 

string dataTableXml = writer.ToString(); 

至于以可读格式显示它,我建议将XML传递给XSL转换器,然后您可以使用它来解析XML并根据需要操作输出。

将XSLT转换应用于数据集

http://msdn.microsoft.com/en-us/library/8fd7xytc%28v=vs.71%29.aspx#Y289

这是我创建的一个简单示例,用于解释如何使用XSL转换器。我没有测试过,但它应该非常接近:

DataSet ds = new DataSet(); 
StringBuilder sbXslOutput = new StringBuilder();  

using (XmlWriter xslWriter = XmlWriter.Create(sbXslOutput)) 
{ 
    XslCompiledTransform transformer = new XslCompiledTransform(); 
    transformer.Load("transformer.xsl"); 
    XsltArgumentList args = new XsltArgumentList(); 

    transformer.Transform(new XmlDataDocument(ds), args, xslWriter); 
} 

string dataSetHtml = sbXslOutput.ToString(); 

使用XSLT将XML格式化为HTML

这是使用XSLT将XML转换为HTML表的示例。它应该相当容易采用,因此您可以将它与序列化的DataSet一起使用。

假设这是您的DataSet,序列化为XML:

<RecentMatter>  
  <UserLogin>PSLTP6\RJK</UserLogin>  
  <MatterNumber>99999-2302</MatterNumber>  
  <ClientName>Test Matters</ClientName>  
  <MatterName>DP Test Matter</MatterName>  
  <ClientCode>99999</ClientCode>  
  <OfficeCode/>  
  <OfficeName/>  
  <Billable>true</Billable>  
  <ReferenceId/>  
  <LastUsed>2011-08-23T23:40:24.13+01:00</LastUsed>  
</RecentMatter>  
<RecentMatter>  
  <UserLogin>PSLTP6\RJK</UserLogin>  
  <MatterNumber>999991.0002</MatterNumber>  
  <ClientName>Lathe 1</ClientName>  
  <MatterName>LW Test 2</MatterName>  
  <ClientCode/>  
  <OfficeCode/>  
  <OfficeName/>  
  <Billable>true</Billable>  
  <ReferenceId/>  
  <LastUsed>2011-07-12T16:57:27.173+01:00</LastUsed>  
</RecentMatter>  
<RecentMatter>  
  <UserLogin>PSLTP6\RJK</UserLogin>  
  <MatterNumber>999991-0001</MatterNumber>  
  <ClientName>Lathe 1</ClientName>  
  <MatterName>LW Test 1</MatterName>  
  <ClientCode/>  
  <OfficeCode/>  
  <OfficeName/>  
  <Billable>false</Billable>  
  <ReferenceId/>  
  <LastUsed>2011-07-12T01:59:06.887+01:00</LastUsed>  
</RecentMatter>  
</NewDataSet>  

这是一个将DataSet转换为HTML的XSLT脚本:

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0"> 
  <xsl:template match="/"> 
      <table border="1"> 
        <tr> 
          <th>User Login</th> 
          <th>Matter Number</th> 
          ... 
        </tr> 
        <xsl:for-each select="NewDataSet/RecentMatter"> 
          <tr> 
            <td> 
              <xsl:value-of select="UserLogin"/> 
            </td> 
            <td> 
              <xsl:value-of select="MatterNumber"/> 
            </td> 
            ... 
          </tr> 
        </xsl:for-each> 
      </table> 
  </xsl:template> 
</xsl:stylesheet> 

答案 1 :(得分:0)

使用XSLT 2.0,您可以利用模式信息(对于源文档和目标文档),使系统能够检查样式表的正确性,如果您尝试访问输入或生成输出,则会给出编译时警告对架构无效。但我不知道有任何工具使用模式来自动创建样式表的过程。可能是某些XSLT编辑工具(IDE)使用模式信息来帮助进行语法导向编辑。