我有一个DataSet,其中包含我输出(写入)XMl文件的数据。
我在数据集中添加了一个名称空间和前缀,如下所示:
public static string XmlNamespace = "http://namespace";
public static string XmlPrefix = "ns0";
RequestDataSet.Namespace = XmlNamespace;
RequestDataSet.Prefix = XmlPrefix;
XML输出如下:
<?xml version="1.0" standalone="yes"?>
<ns0:list xmlns:ns0="http://namespace">
<ns0:item xmlns="http://namespace">
<data1>1234</data1>
<data2>91011</data2>
</item>
</ns0:list>
但它应该是这样的:(项目记录上没有命名空间。只是前缀)
<?xml version="1.0" standalone="yes"?>
<ns0:list xmlns:ns0="http://namespace">
<ns0:item>
<data1>1234</data1>
<data2>91011</data2>
</item>
</ns0:list>
我尝试将表格前缀/名称空间设置为null,如下所示:
RequestDataSet.Tables["item"].Prefix = XmlPrefix;
RequestDataSet.Tables["item"].Namespace = null;
但这也行不通......有没有人知道这方面的解决方案?
答案 0 :(得分:0)
在使用BizTalk适配器进行战斗时,我遇到了类似的问题......但这是一个不同的故事。
不确定是否有不同(更干净)的方式,但您可以随时“抓取”该属性并将其删除,如here所述。
有效地,您将执行以下操作:
XmlDocument xDoc = new XmlDocument();
xDoc.LoadXml(xml);
if (xDoc.DocumentElement.Attributes.Count > 0)
{
XmlAttribute xAtt = xDoc.DocumentElement.Attributes[0];
xDoc.DocumentElement.Attributes.Remove(xAtt);