7

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"myWriter.WriteStartDocument();また、変換前に(C#で)コードを追加しようとしましたが、それは許可されませんでした。私もこれをオンラインで検索して戻ってきましたstandalone="yes"が、うまくいきません。ここに欠けているものはありますか?ああ、あなたがなぜ私が持っている必要があるのか​​疑問に思っている場合に備えて

<?xml version="1.0"?>

結果のファイルの上部にあるのは、Excelでxmlファイルを開くと、Excelが正しく認識しないためですが、含まれている場合、Excelは正しく開きます...

4

1 に答える 1

6

あなたはこれを行うことができます

<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。私はあなたがあなたのニーズに適応できると確信しています。

于 2012-05-02T18:10:08.773 に答える