0

我正在尝试格式化 XML 文件,以便可以使用 Microsoft Excel 直接打开它。

我遇到的问题是由于默认命名空间和别名 ss: 命名空间是相同的。否则我无法让 excel 接受该文件。

当尝试下面的代码时,我在 WorkSheet 节点上获得了一个额外的 xmlns="" 属性。这使 Excel 无法打开该文件。

XNamespace nsDefault = "urn:schemas-microsoft-com:office:spreadsheet";
XElement workbook = new XElement(nsDefault + "Workbook", 
    new XAttribute("xmlns", nsDefault),
new XAttribute(XNamespace.Xmlns + "ss", nsDefault));

XElement worksheet = new XElement("Worksheet");
worksheet.SetAttributeValue(nsDefault + "Name", "Shipping");

XElement table = new XElement("Table");

XElement row = new XElement("Row");
XElement cell = new XElement("Cell");
XElement data = new XElement("Data");
data.SetAttributeValue(nsDefault + "Type", "String");
data.Value = "qwerty";

cell.Add(data);
row.Add(cell);
table.Add(row);

worksheet.Add(table);
workbook.Add(worksheet);

workbook.Save(@".\Xml\Test.xml");

有谁知道我该如何解决这个问题?

4

1 回答 1

0

你最好使用Open XML SDK微软提供的。从此处获取有关它的更多信息:

http://msdn.microsoft.com/en-us/library/office/hh180830.aspx

http://blogs.msdn.com/b/chrisquon/archive/2009/07/22/creating-an-excel-spreadsheet-from-scratch-using-openxml.aspx

于 2012-08-22T14:44:31.557 回答