我尝试使用这个代码:[C#]
var textReader = new XmlTextReader(path);
if (textReader.NamespaceURI == "http://www.portalfiscal.inf.br/nfe")
{
//...
}
我的XML:
<?xml version="1.0" encoding="utf-8"?>
<NFe xmlns="http://www.portalfiscal.inf.br/nfe">
<infNFe version="2.00" Id="NFe31130317194994450127550012302143751002144567">
<ide>
//continue...
但我的代码总是返回“” ...
有没有一种简单的方法来获取XML命名空间?
您的代码将返回当前节点的namespaceURI。
尝试XML流中推进:
var textReader = new XmlTextReader(path);
while(reader.NodeType != XmlNodeType.Element) textReader.Read();
if (textReader.NamespaceURI == "http://www.portalfiscal.inf.br/nfe")
{
//...
}
这里是一个不错的方法,LINQ:
XDocument z = XDocument.Parse(s);
var result = z.Root.Attributes().
Where(a => a.IsNamespaceDeclaration).
GroupBy(a => a.Name.Namespace == XNamespace.None ? String.Empty : a.Name.LocalName,
a => XNamespace.Get(a.Value)).
ToDictionary(g => g.Key,
g => g.First());
发现这种方法多在hanselmans网站:从XPathDocument中和LINQ to XML XML文档获取命名空间
然后根据需要刚刚经历字典循环。