添加到 xml 文件的顶部-6ren"> 添加到 xml 文件的顶部-我已经成功地使用 xsl 模板将一个带有数据的简单 xml 文件转换为另一个 xml 文件(excel 模板),这就是我的 xsl 文件的样子: -6ren">
gpt4 book ai didi

c# - 在 xsl 转换后将 添加到 xml 文件的顶部

转载 作者:数据小太阳 更新时间:2023-10-29 01:48:03 27 4
gpt4 key购买 nike

我已经成功地使用 xsl 模板将一个带有数据的简单 xml 文件转换为另一个 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 无法正确识别它,但如果包含它,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 实例而编写的。我相信您可以适应您的需求。

关于c# - 在 xsl 转换后将 <?xml version ="1.0"?> 添加到 xml 文件的顶部,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10419254/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com