草庐IT

c# - 样式化 xml 返回相同的 xml 文档,一种让代码工作的方法

coder 2024-07-05 原文

 SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["ICDBConnectionString"].ConnectionString);
        conn.Open();

        string SQL = "Select TUReportData from TUReport WHERE ConsumerID = @ConsumerID";

        SqlCommand cmd = new SqlCommand(SQL, conn);
        cmd.Parameters.Add(new SqlParameter("@ConsumerID", txtIDNumber.Text));

        SqlDataAdapter adapter = new SqlDataAdapter(cmd);

        DataTable dt = new DataTable();
        adapter.Fill(dt);

        dt.TableName = "XMLData";
        dt.ToString();
        dt.WriteXml("C:/inetpub/wwwroot/TUWebServiceCaller/Log/temp.xml");

        // Getting file path    
        string strXSLTFile = Server.MapPath("styles/style.xslt");
        string strXMLFile = Server.MapPath("Log/temp.xml");

        // Creating XSLCompiled object    
        XslCompiledTransform objXSLTransform = new XslCompiledTransform();
        objXSLTransform.Load(strXSLTFile);

        // Creating StringBuilder object to hold html data and creates TextWriter object to hold data from XslCompiled.Transform method    
        StringBuilder htmlOutput = new StringBuilder();
        TextWriter htmlWriter = new StringWriter(htmlOutput);

        // Creating XmlReader object to read XML content    
        XmlReader reader = XmlReader.Create(strXMLFile);

        // Call Transform() method to create html string and write in TextWriter object.    
        objXSLTransform.Transform(reader, null, htmlWriter);
        Results.InnerHtml  = htmlOutput.ToString();

        // Closing xmlreader object    
        reader.Close();

运行时没有错误,但 XSLT 似乎没有对 XML 进行样式设置,因为它以与传入的格式相同的格式返回。整个 xml 应该重新格式化,我自己的整个页面版本与节点一起显示我已经指定到位了

XSLT 这就是 XSLT 示例

<xsl:for-each select="AddressNA08">
    <tr>
        <td>
            <xsl:value-of select="ConsumerNo"/>
        </td>
        <td>
            <xsl:value-of select="InformationDate"/>
        </td>
        <td>
            <xsl:value-of select="Line1"/>
        </td>
        <td>
            <xsl:value-of select="Line2"/>
        </td>
        <td>
            <xsl:value-of select="Suburb"/>
        </td>
        <td>
            <xsl:value-of select="City"/>
        </td>
        <td>
            <xsl:value-of select="PostalCode"/>
        </td>
        <td>
            <xsl:value-of select="ProvinceCode"/>
        </td>
        <td>
            <xsl:value-of select="Province"/>
        </td>
        <td>
            <xsl:value-of select="AddressPeriod"/>
        </td>
        <td>
            <xsl:value-of select="OwnerTenant"/>
        </td>
        <td>
            <xsl:value-of select="AddressChanged"/>
        </td>
    </tr>
</xsl:for-each>

XML

<AddressNA08>
    <ConsumerNo>645511310</ConsumerNo>
    <InformationDate>20090227</InformationDate>
    <Line1>8 HAAKBOS ST</Line1>
    <Line2 />
    <Suburb>ONVERWACHT</Suburb>
    <City>ELLISRAS</City>
    <PostalCode>0557</PostalCode>
    <ProvinceCode>
        NP
    </ProvinceCode>
    <Province>LIMPOPO</Province>
    <AddressPeriod>
        06
    </AddressPeriod>
    <OwnerTenant>O</OwnerTenant>
    <AddressChanged>N</AddressChanged>
</AddressNA08>

这些都是我正在使用的文件

最佳答案

使用这样的方法,我通过 xslt 将 xml 转换为 xhtml:

   public static XmlDocument TransformToHtml(XmlDocument XmlDoc, XmlDocument XSLT) {

        var bArr = new System.Text.UTF8Encoding().GetBytes(XmlDoc.InnerXml);
        MemoryStream m = new MemoryStream(bArr);
        System.Xml.XPath.XPathDocument xDoc;
        XmlReaderSettings xrs = new XmlReaderSettings();
        xrs.CheckCharacters = false;
        using (XmlReader xr = XmlReader.Create(m, xrs)) {
            xDoc = new System.Xml.XPath.XPathDocument(xr);
        }

        StringBuilder resultString = new StringBuilder();
        var ws = new XmlWriterSettings();
        ws.CheckCharacters = false;
        ws.Indent = true;
        ws.OmitXmlDeclaration = true;
        XmlWriter writer = XmlWriter.Create(resultString, ws);
        var sets = new XsltSettings(true, true);

        string transformedXHTML = null;
        XslCompiledTransform transform = new XslCompiledTransform(false);
        transform.Load(XSLT, sets, null);
        transform.Transform(xDoc, writer);
        transformedXHTML = resultString.ToString();
        var doc = new XmlDocument();
        doc.LoadXml(transformedXHTML);
        return doc;
    }

你这样调用它(注意,缩短你的 xslt!):

        var xml = new XmlDocument();
        xml.LoadXml("<AddressNA08><ConsumerNo>645511310</ConsumerNo><InformationDate>20090227</InformationDate><Line1>8 HAAKBOS ST</Line1><Line2 />"
                   + "<Suburb>ONVERWACHT</Suburb><City>ELLISRAS</City><PostalCode>0557</PostalCode><ProvinceCode>NP</ProvinceCode><Province>LIMPOPO</Province>"
                   + "<AddressPeriod>06</AddressPeriod><OwnerTenant>O</OwnerTenant><AddressChanged>N</AddressChanged></AddressNA08>");

        var xslt = new XmlDocument();
        xslt.LoadXml("<xsl:stylesheet xmlns:xsl='http://www.w3.org/1999/XSL/Transform' xmlns='http://www.w3.org/1999/xhtml' version='1.0'>" +
                     "<xsl:output encoding='UTF-8' indent='yes' method='xml' standalone='no' omit-xml-declaration='no'/><xsl:template match='/'><xsl:for-each select='AddressNA08'>" +
                     "<tr><td><xsl:value-of select='ConsumerNo'/></td><td><xsl:value-of select='InformationDate'/></td><td><xsl:value-of select='Line1'/></td>" +
                     "<td><xsl:value-of select='Line2'/></td><td><xsl:value-of select='Suburb'/></td></tr></xsl:for-each></xsl:template></xsl:stylesheet>");
        var reslt = TransformToHtml(xml, xslt);

关于c# - 样式化 xml 返回相同的 xml 文档,一种让代码工作的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34197366/

有关c# - 样式化 xml 返回相同的 xml 文档,一种让代码工作的方法的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  4. ruby - Facter::Util::Uptime:Module 的未定义方法 get_uptime (NoMethodError) - 2

    我正在尝试设置一个puppet节点,但ruby​​gems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由ruby​​gems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby

  5. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  6. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  7. Ruby 方法() 方法 - 2

    我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby​​-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco

  8. ruby - 如何在 buildr 项目中使用 Ruby 代码? - 2

    如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby​​

  9. ruby-on-rails - Rails 源代码 : initialize hash in a weird way? - 2

    在rails源中:https://github.com/rails/rails/blob/master/activesupport/lib/active_support/lazy_load_hooks.rb可以看到以下内容@load_hooks=Hash.new{|h,k|h[k]=[]}在IRB中,它只是初始化一个空哈希。和做有什么区别@load_hooks=Hash.new 最佳答案 查看rubydocumentationforHashnew→new_hashclicktotogglesourcenew(obj)→new_has

  10. ruby - 为什么 4.1%2 使用 Ruby 返回 0.0999999999999996?但是 4.2%2==0.2 - 2

    为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返

随机推荐