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/
我正在学习如何使用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
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
类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
我正在尝试设置一个puppet节点,但rubygems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由rubygems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby
我在从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""-
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco
如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby
在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
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返