xml to json using xslt



正在尝试通过使用C#中的以下代码应用XSLT变换来将XML转换为JSON转换。有以下错误的错误可以在下面建议我吗?代码:

 Li = p.GetRegisterEntry();
        var std = Li.Where(s => s.Id == id).FirstOrDefault();
        string xml = std.contentxml.Value;
        doc.LoadXml(xml);            
        string XSLT = std.TemplateXSLT.Value;
        Xslt.LoadXml(XSLT);            
        XslCompiledTransform xslt = new XslCompiledTransform();
        xslt.Load(Xslt.CreateNavigator());           
        // Transform our Xml-ified JSON
        var outputDocument = new XmlDocument();
        var stream = new MemoryStream();
        xslt.Transform(doc, null, stream);
        var sr = new StreamReader(stream);
        var myStr = sr.ReadToEnd();
        stream.Position = 0;
        outputDocument.Load(stream);
        // Convert back to JSON
        string jsonText = JsonConvert.SerializeXmlNode(outputDocument);

正在outputDocument.load(stream(上遇到以下错误;system.xml.dll中出现了" system.xml.xmlexception"类型的例外其他信息:有多个根元素。第2行,位置2。

任何人都可以帮我破解吗?

这是我的XML和XSTL文件XML:

   <NewDataSet>
      <RegisterEntry type="CM2" desc="Request to Change Name, Address and /or Singapore Address for Service for Agent, Applicant/Proprietor and/or other interested Parties">
        <EventDate>23/09/2051</EventDate>
        <DataItems>
          <LodgementDate>26/08/2022</LodgementDate>
          <DecisionDate>21/12/2031</DecisionDate>
          <Particulars>
            <Particular>
              <TransactionType>Test Data</TransactionType>
              <Details>Test Data</Details>
            </Particular>
          </Particulars>
        </DataItems>
      </RegisterEntry>
    </NewDataSet>

XSLT:

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
  <xsl:output method="html" />
  <xsl:template match="RegisterEntry">
    <p>      Test Data Parties<xsl:value-of select="DataItems/TransactionType" /></p>
    <div id="content">
      <table>
        <tr>
          <th valign="top" align="left">            Lodgement Date          </th>
          <td>
            <xsl:value-of select="DataItems/LodgementDate" />
          </td>
        </tr>
        <tr>
          <th valign="top" align="left">            Decision Date          </th>
          <td>
            <xsl:value-of select="DataItems/DecisionDate" />
          </td>
        </tr>
        <xsl:for-each select="DataItems/Particulars/Particular">
          <tr>
            <th valign="top" align="left" style="width:50%">    Test Data <xsl:value-of select="TransactionType" /></th>
            <td>
              <xsl:value-of select="Details" />
            </td>
          </tr>
        </xsl:for-each>
      </table>
    </div>
  </xsl:template>
</xsl:stylesheet>

正如蒂姆(Tim(指出的,问题是您的XSLT不会创建可以使用XmlDocument加载良好的XML文档,而只是片段。因此,如果您需要XmlNode的结果,则可以使用其他方法使用其他方法。

XmlDocument resultDoc = new XmlDocument();
XmlDocumentFragment resultFrag = resultDoc.CreateDocumentFragment();
using (XmlWriter xw = resultFrag.CreateNavigator().AppendChild())
{
  xslt.Transform(doc, null, xw);
  xw.Close();
}
string jsonText = JsonConvert.SerializeXmlNode(resultFrag);

您的Libray JonConvert是否能够处理我不知道的文档片段。

最新更新