8

XmlElement.Attributes.Remove* 方法适用于任意属性,导致从 XmlDocument.OuterXml 属性中删除已删除的属性。但是 Xmlns 属性是不同的。这是一个例子:

XmlDocument doc = new XmlDocument();
doc.InnerXml = @"<Element1 attr1=""value1"" xmlns=""http://mynamespace.com/"" attr2=""value2""/>";
doc.DocumentElement.Attributes.RemoveNamedItem("attr2");
Console.WriteLine("xmlns attr before removal={0}", doc.DocumentElement.Attributes["xmlns"]);
doc.DocumentElement.Attributes.RemoveNamedItem("xmlns");
Console.WriteLine("xmlns attr after removal={0}", doc.DocumentElement.Attributes["xmlns"]);

结果输出是

xmlns attr before removal=System.Xml.XmlAttribute
xmlns attr after removal=
<Element1 attr1="value1" xmlns="http://mynamespace.com/" />

该属性似乎已从 Attributes 集合中删除,但并未从 XmlDocument.OuterXml 中删除。我猜是因为这个属性的特殊含义。

问题是如何使用 .NET XML API 删除 xmlns 属性。显然我可以从这个字符串表示中删除属性,但我想知道是否可以使用 API 做同样的事情。

@Edit:我说的是.NET 2.0。

4

9 回答 9

3

非常感谢 Ali Shah,这个帖子完美地解决了我的问题!这是一个 C# 转换:

var dom = new XmlDocument();
        dom.Load("C:/ExampleFITrade.xml));
        var loaded = new XDocument();
        if (dom.DocumentElement != null)
            if( dom.DocumentElement.NamespaceURI != String.Empty)
            {
                dom.LoadXml(dom.OuterXml.Replace(dom.DocumentElement.NamespaceURI, ""));
                dom.DocumentElement.RemoveAllAttributes();
                loaded = XDocument.Parse(dom.OuterXml);
            }
于 2010-02-12T12:05:30.453 回答
2

.NET DOM API 不支持修改元素的命名空间,而这实际上是您想要做的。因此,为了解决您的问题,您必须以一种或另一种方式构建一个新文档。您可以使用相同的 .NET DOM API 并创建一个新元素,而无需指定其命名空间。或者,您可以创建一个 XSLT 样式表,将您原来的“命名空间”文档转换为一个新文档,其中的元素将不是命名空间限定的。

于 2008-09-16T20:51:51.417 回答
2

这不应该删除名称空间吗?

XmlNamespaceManager mgr = new XmlNamespaceManager("xmlnametable");
mgr.RemoveNamespace("prefix", "uri");

但无论如何,在这里切线,来自 System.Xml.Linq 命名空间 (.Net 3.0) 的 XElement、XDocument 和XNameSpace 类比旧的 XmlDocument 模型好很多。搏一搏。我上瘾了。

于 2008-09-16T21:46:26.310 回答
2

我在这个线程中看到了各种选项,并来解决我自己的删除 xml 中的 xmlns 属性的解决方案。这工作正常,没有问题:

'Remove the Equifax / Transunian / Experian root node attribute that have xmlns and load xml without xmlns attributes.
If objXMLDom.DocumentElement.NamespaceURI <> String.Empty Then
  objXMLDom.LoadXml(objXMLDom.OuterXml.Replace(objXMLDom.DocumentElement.NamespaceURI, ""))
  objXMLDom.DocumentElement.RemoveAllAttributes()
  ResponseXML = objXMLDom.OuterXml
End If

无需执行任何其他操作即可从 xml 中删除 xmlns。

于 2009-12-09T16:21:14.037 回答
1
public static string RemoveXmlns(string xml)
{
    //Prepare a reader
    StringReader stringReader = new StringReader(xml);
    XmlTextReader xmlReader = new XmlTextReader(stringReader);
    xmlReader.Namespaces = false; //A trick to handle special xmlns attributes as regular
    //Build DOM
    XmlDocument xmlDocument = new XmlDocument();
    xmlDocument.Load(xmlReader);
    //Do the job
    xmlDocument.DocumentElement.RemoveAttribute("xmlns"); 
    //Prepare a writer
    StringWriter stringWriter = new StringWriter();
    XmlTextWriter xmlWriter = new XmlTextWriter(stringWriter);
    //Optional: Make an output nice ;)
    xmlWriter.Formatting = Formatting.Indented;
    xmlWriter.IndentChar = ' ';
    xmlWriter.Indentation = 2;
    //Build output
    xmlDocument.Save(xmlWriter);
    return stringWriter.ToString();
}
于 2013-01-11T22:14:13.190 回答
0

是的,因为它是一个 ELEMENT 名称,所以您不能明确删除它。使用 XmlTextWriter 的 WriteStartElement 和 WirteStartAttribute,并用空格替换属性可能会完成工作。

我现在正在检查它。将更新。

于 2008-09-16T20:20:24.067 回答
0

也许通过 XmlNamespaceManager ?http://msdn.microsoft.com/en-us/library/system.xml.xmlnamespacemanager.removenamespace.aspx但这只是一个猜测。

于 2008-09-16T20:35:09.880 回答
0

我们可以将 xml 转换为字符串,从该字符串中删除 xmlns,然后使用该字符串创建另一个 XmlDocument,它没有命名空间。

于 2009-06-10T09:36:19.643 回答
0

这是我在 vb.net 上的解决方案!

   Dim pathXmlTransformado As String = "C:\Fisconet4\process\11790941000192\2015\3\28\38387-1\38387_transformado.xml"
    Dim nfeXML As New XmlDocument
    Dim loaded As New XDocument

    nfeXML.Load(pathXmlTransformado)

    nfeXML.LoadXml(nfeXML.OuterXml.Replace(nfeXML.DocumentElement.NamespaceURI, ""))
    nfeXML.DocumentElement.RemoveAllAttributes()

    Dim dhCont As XmlNode = nfeXML.CreateElement("dhCont")
    Dim xJust As XmlNode = nfeXML.CreateElement("xJust")
    dhCont.InnerXml = 123
    xJust.InnerXml = 123777

    nfeXML.GetElementsByTagName("ide")(0).AppendChild(dhCont)
    nfeXML.GetElementsByTagName("ide")(0).AppendChild(xJust)

    nfeXML.Save("C:\Fisconet4\process\11790941000192\2015\3\28\38387-1\teste.xml")
于 2015-03-28T18:40:13.003 回答