利用XPath解析带有xmlns的XML文件
在.net中,编写读取xml 的程序中提示"未将对象引用设置到对象的实例",当时一看觉得有点奇怪.为什么在读取xml数据的时候也要实例化一个对象.google了才知道,xml文件中加入了xmlns表示名称空间,但同时Xpath也必须加上.
如之前我们的xml文件定义为:
<Project Name="目标计划项目"> <Process Name="个人月度计划" Description="个人月度计划" Version="1"> <Node Name="开始" Type="Start" Description="开始"> <Event></Event> </Node> </Process> </Project>
我们读取只需
XmlDocument xmlDoc = new XmlDocument(); xmlDoc.Load(path); string xPath = @"Project/Process"; XmlNode xn = xmlDoc.SelectSingleNode(xPath);
这样编写
若xml这样定义
<Project xmlns="http://tempuri.org/XMLSchema.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://tempuri.org/XMLSchema.xsd WFPD.xsd" Name="目标计划项目"> <Process Name="个人月度计划" Description="个人月度计划" Version="1"> <Node Name="开始" Type="Start" Description="开始"> <Event></Event> </Node> </Process> </Project>
我们读取的时候必须这样调用
XmlDocument xmlDoc = new XmlDocument(); xmlDoc.Load(path); XmlNamespaceManager xnm = new XmlNamespaceManager(xmlDoc.NameTable); xnm.AddNamespace("mxh", "http://tempuri.org/XMLSchema.xsd"); string xPath = @"/mxh:Project/mxh:Process"; XmlNode xn = xmlDoc.SelectSingleNode(xPath, xnm);
这个破问题困惑了我一晚上,终于搞定了。
解决的过程大概是:通过解析一个简单的不带xmlns的文件,证明自己的XPath表达式是正确的。因此问题出在XML文件的结构差异上。实验了大概n百回,终于发现xmlns这家伙看着怪怪的。百度了一下“xml xmlns”,马上就看到前人已经遇到这个问题的帖子及解决办法。
上面除了最后两段话和题目,都引自别人文章,因为别人说的够明确了,呵呵。利用XPath解析XML文件之——都是xmlns惹的祸