在 xsl 转换后,将 添加到 xml 文件的顶部

本文关键字:xml 添加 顶部 文件 转换 xsl version | 更新日期: 2023-09-27 18:32:52

我已经能够使用 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)...

我正在使用以下代码通过窗口窗体进行此转换:

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 转换后,将 <?xml version=“1.0” ?> 添加到 xml 文件的顶部

你可以

这样做

<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的实例。我相信你可以适应你的需求。