[英]Add <?xml version=“1.0” ?> to the top of a xml file after xsl transform
我已成功能夠改變一個簡單的XML文件與數據使用XSL模板另一個XML文件(Excel模板),這是我的XSL文件的樣子:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="xml" standalone="yes"/>
<xsl:template match="/">
<xsl:processing-instruction name="mso-application">
<xsl:text>progid="Excel.Sheet"</xsl:text>
</xsl:processing-instruction>
...(stuff here)...
</xsl:template>
</xsl:stylesheet>
生成的xml文件正確寫出,但包含除外
<?xml version="1.0"?>
在文件的頂部。 如何讓它出現在頂部?
目前我生成的xml文件以:
<?mso-application progid="Excel.Sheet"?>
...(rest of file)...
但我需要做的是:
<?xml version="1.0"?>
<?mso-application progid="Excel.Sheet"?>
.(rest of file)...
我正在使用以下代碼通過Windows窗體進行此轉換:
XPathDocument myXPathDoc = new XPathDocument(xmlfile);
XslCompiledTransform myXslTrans = new XslCompiledTransform();
myXslTrans.Load(xslfile);
XmlTextWriter myWriter = new XmlTextWriter(xmlexcelfile, null);
myWriter.Formatting = Formatting.Indented;
myWriter.Namespaces = true;
myXslTrans.Transform(myXPathDoc, null, myWriter);
myWriter.Close();
我嘗試過使用xsl:output standalone="yes/no"
,以及omit-xml-declaration="no"
。 我也試過(在C#中)代碼添加myWriter.WriteStartDocument();
在轉型之前,但這是不允許的。 我也嘗試在網上搜索這個並繼續回到standalone="yes"
但這不起作用。 這里有什么我想念的嗎? 哦,萬一你想知道為什么我需要
<?xml version="1.0"?>
在生成的文件的頂部,這是因為打開使用Excel XML文件時,Excel不能正確識別,但如果包括它,然后練成正確打開它...
你可以這樣做
<xsl:output method="xml" indent="yes" omit-xml-declaration="no" />
或類似於使用XmlWriterSettings
東西
編輯 :添加更多代碼。 以前缺少一些部分
XmlWriterSettings writerSettings = null;
XsltArgumentList transformationArguments = null;
XslCompiledTransform transformer = null;
MemoryStream memoryStream = null;
XPathDocument xPathDocument = null;
StringBuilder sb = null;
XmlWriter writer = null;
XmlDocument resultXml = null;
try
{
writerSettings = new XmlWriterSettings();
writerSettings.OmitXmlDeclaration = false; // This does it
writerSettings.Indent = true;
transformationArguments = new XsltArgumentList();
transformer = new XslCompiledTransform();
memoryStream = new MemoryStream(System.Text.Encoding.Default.GetBytes(xml.OuterXml));
xPathDocument = new XPathDocument(new StreamReader(memoryStream));
sb = new StringBuilder();
// give the settings to the writer here
writer = XmlWriter.Create(sb, writerSettings);
// this is not mandatory, obviously, just passing parameters to my xslt file
foreach (KeyValuePair<string, object> parameter in parameters)
{
transformationArguments.AddParam(parameter.Key, string.Empty, parameter.Value);
}
using (Stream strm = Assembly.GetExecutingAssembly().GetManifestResourceStream("Lib.XSLTFile1.xslt"))
using (XmlReader reader = XmlReader.Create(strm))
{
transformer.Load(reader);
transformer.Transform(xPathDocument, transformationArguments, writer);
}
resultXml = new XmlDocument();
resultXml.LoadXml(sb.ToString());
// for testing only
File.AppendAllText(@"Your path goes here\result.xml", resultXml.OuterXml);
}
catch (Exception)
{
throw;
}
這就是我這樣做的方法,但是這段代碼專門用於創建XmlDocument
的實例。 我相信你能適應你的需求。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.