解析xml语法错误时出错

时间:2018-02-02 14:26:27

标签: c# xml

我在下面有以下代码。我收到了一个错误"字符':'十六进制值0x3A不能包含在名称中#34;谁能告诉我如何解决这个问题? 谢谢以下是整个代码

 public static XDocument GenerateXMLSpreadSheet(DataTable tbl)
    {
         new XDocument(   
            new XDeclaration("1.0", "utf-8", "yes"),   
            new XProcessing**Instruction("mso-application", "Excel.Sheet"),   
            new XElement("Workbook",   
                new XAttribute("xmlns", "urn:schemas-microsoft-com:office:spreadsheet"),   
                new XAttribute("xmlns:ss", "urn:schemas-microsoft- 
                      com:office:spreadsheet"),   
                    new XElement("Worksheet", new XAttribute("ss:Name",  
                        tbl.TableName),
                        new XElement("Table", GetRows(tbl)   
                        )
                    )
                )
            );
        return xmlssDoc;    
)
 public static Object[] GetRows(DataTable tbl)
    {
        // generate XElement rows for each row in the database.
        // generate from the bottom-up.
        // start with the cells.
        XElement[] rows = new XElement[tbl.Rows.Count];

        int r = 0;
        foreach (DataRow row in tbl.Rows)
        {
            // create the array of cells to add to the row:
            XElement[] cells = new XElement[tbl.Columns.Count];
            int c = 0;
            foreach (DataColumn col in tbl.Columns)
            {
                cells[c++] =
                    new XElement("Cell",
                        new XElement("Data", new XAttribute("ss:Type", "String"),
                            new XText(row[col].ToString())));
            }
            rows[r++] = new XElement("Row", cells);
        }
        // return the array of rows.
        return rows;
    }

2 个答案:

答案 0 :(得分:5)

基本上,这不是你如何处理LINQ to XML中的命名空间。你从不指定带冒号的字符串 - 而是从XName和字符串中构建XNamespace

好消息是LINQ to XML处理命名空间很简单。这是一个完整的例子:

using System;
using System.Xml.Linq;

public class Test
{
    static void Main(string[] args)
    {
        XNamespace ns = "urn:schemas-microsoft-com:office:spreadsheet";
        var doc = new XDocument(   
            new XDeclaration("1.0", "utf-8", "yes"),   
            new XProcessingInstruction("mso-application", "Excel.Sheet"),   
            new XElement(ns + "Workbook",
                new XAttribute("xmlns", ns),
                new XAttribute(XNamespace.Xmlns + "ss", ns),
                new XElement(ns + "Worksheet", 
                   new XAttribute(ns + "Name", "my-table-name"),
                   new XElement(ns + "Table")
                )
            )
        );
        Console.WriteLine(doc);
    }
}

输出(为清晰起见重新格式化):

<?mso-application Excel.Sheet?>
<ss:Workbook
    xmlns="urn:schemas-microsoft-com:office:spreadsheet" 
    xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet">
  <ss:Worksheet ss:Name="my-table-name">
    <ss:Table />
  </ss:Worksheet>
</ss:Workbook>

请注意您需要为所有元素和属性指定命名空间。

因为您已为命名空间指定了显式前缀,所以LINQ to XML会在任何地方使用它。如果删除此部分:

new XAttribute(XNamespace.Xmlns + "ss", ns)

...然后将默认元素的名称空间,LINQ to XML将为需要明确指定的属性生成前缀(因为属性不会默认其名称空间)。

然后输出(例如):

<?mso-application Excel.Sheet?>
<Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet">
  <Worksheet p2:Name="my-table-name" xmlns:p2="urn:schemas-microsoft-com:office:spreadsheet">
    <Table />
  </Worksheet>
</Workbook>

答案 1 :(得分:1)

问题在于您如何定义命名空间 要使用命名空间,您可以通过调用XNamespace.Get("the namespace")并在任何地方使用它来获取命名空间。

对于xmlns,您可以使用静态属性XNamespace.Xmlns

所以最终的代码如下:

new XDocument(
    new XDeclaration("1.0", "utf-8", "yes"),
    new XProcessingInstruction("mso-application", "Excel.Sheet"),
    new XElement("Workbook",
        new XAttribute("xmlns", ns),
        new XAttribute(XNamespace.Xmlns + "ss", ns),   

            new XElement("Worksheet", new XAttribute(ns + "Name",
                tbl.TableName),
                new XElement("Table", GetRows(tbl)
                )
            )
        )
    );