C# XML解析方式实例解析

简介:

C# XML解析通过XPath的方式是如何办到的呢?具体的操作步骤是什么呢?那么下面我们就向你介绍通过XPath的方式来实现C# XML解析,希望对你了解C# XML解析有所帮助。

C# XML解析通过XPath的方式的步骤:

1、需要先加载文档,然后再读取想要的节点值。

◆xml文档

protected XmlDocument doc = null;

◆xml文档的根元素(节点)

protected XmlElement root = null;

◆xml文档的名空间管理器

protected XmlNamespaceManager nsmgr = null;

2、接下来就是加载文档了

protected void LoadXmlFile(FileInfo xmlFile)    {  if (xmlFile == null || !xmlFile.Exists)  {   throw new FileNotFoundException(  string.Format("要解析的文件不存在{0}。",  xmlFile.FullName));  }  //加载文件  this.doc = new XmlDocument();  doc.Load(xmlFile.FullName);  //准备读取文件  root = doc.DocumentElement;  string nameSpace = root.NamespaceURI;  nsmgr = new XmlNamespaceManager(doc.NameTable);  nsmgr.AddNamespace("ns", nameSpace);    } 

◆C# XML解析通过XPath的方式要注意。

a、这两行是取得xml文档的名空间

root = doc.DocumentElement;  string nameSpace = root.NamespaceURI; 

b、这两行是建立xml文档的名空间管理器

nsmgr = new XmlNamespaceManager(doc.NameTable);  nsmgr.AddNamespace("ns", nameSpace); 

如果你的xml文档有名空间,则这部分的代码是必不可少的。

3、接下来就是读取文档节点的值了

这里两个传入参数prefixPath是节点的上级节点路径,xRelativePath是要读取的节点名称。

另外,变量XmlFileInfo是要加载的xml文件。

protected string GetNodeValue(  string prefixPath, string xRelativePath)    {  if (doc == null)  {   LoadXmlFile(XmlFileInfo);  }  string xPath = string.Empty;  if (!string.IsNullOrEmpty(xRelativePath))  {   if (!string.IsNullOrEmpty(prefixPath))   {    xPath = prefixPath + xRelativePath;   }   else  {    xPath = xRelativePath;   }  }  xPath = xPath.Replace("/", "/ns:");  XmlNode node = root.SelectSingleNode(xPath, nsmgr);  if (node == null)  {   return null;  }  return node.InnerXml;    } 

可能有的朋友要问,为什么要设置两个参数prefixPath和xRelativePath呢,其实这个没有多大的关系,我只是为了自己觉得方便,你也可以在方法外确定了这个XPath,在方法中只设置一个传入参数,效果是一样的。

◆注意这一行:

xPath = xPath.Replace("/", "/ns:"); 

如果你的xml文档带名空间,则这行是比不可少的,否则会出现找不到节点,无法解析的情况。

关于XPath的一些问题:

对于这样一个xml文档,要查找第一个节点下的学生的Name时(ID=01),其XPath应该是"/ns:Root/ns:Students/ns:Student[1]/ns:Name"。xml对于重复的节点名称,是按照顺序1,2,3...的方式遍历的,也就是说如果要找第N个Student节点的下的节点之,那么应使用Student[N]的标识方式。

﹤?xml version="1.0" encoding="UTF-8" ?﹥  ﹤Root xmlns="urn:ClassNameSpace"﹥  ﹤Class﹥  ﹤ClassID﹥1234﹤/ClassID﹥  ﹤/Class﹥  ﹤Students﹥  ﹤Student﹥  ﹤ID﹥01﹤/ID﹥﹤Name﹥Name01﹤/Name﹥  ﹤/Student﹥  ﹤Student﹥  ﹤ID﹥02﹤/ID﹥﹤Name﹥Name02﹤/Name﹥  ﹤/Student﹥  ﹤/Students﹥  ﹤/Root﹥ 

当然,这里也可以获取节点属性的值,查找满足特定值的节点等等,这些和上面获取节点值的过程是类似的。


本文转自左正博客园博客,原文链接:http://www.cnblogs.com/soundcode/archive/2010/12/26/1917473.html,如需转载请自行联系原作者

目录
相关文章
|
1天前
|
机器学习/深度学习 前端开发 JavaScript
HTML基础 + 实例解析(速速来看!!!)
HTML基础 + 实例解析(速速来看!!!)
9 0
|
2天前
|
弹性计算 数据挖掘 应用服务中间件
阿里云服务器通用算力型U1实例解析,实例性能、适用场景及常见问题参考
在阿里云服务器的所有实例规格中,通用算力型u1实例主打的是高性价比,通用算力型U1实例云服务器自推出以来,就受到了广大用户的关注,也是目前阿里云的活动中比较热门的云服务器实例,这个实例规格的性能要好于经济型e等共享型实例,价格又比计算型c7、通用型g7等其他企业级实例要低一些。本文将深入解析通用算力型U1实例的特点、适用场景以及价格优势,帮助用户更好地了解该云服务器实例。
阿里云服务器通用算力型U1实例解析,实例性能、适用场景及常见问题参考
|
2天前
|
XML Web App开发 JavaScript
XML DOM 解析器
浏览器通常内置XML解析器,将XML转换为JavaScript可操作的DOM对象。XML DOM提供遍历、修改XML节点的函数。
|
2天前
|
XML Web App开发 JavaScript
XML DOM 解析器
浏览器内置的XML解析器将XML转换为JavaScript可操作的DOM对象,允许遍历、访问和修改XML节点。要加载XML文档,如"books.xml",可以使用XMLHttpRequest。以下是示例代码:创建XMLHTTP对象,打开GET请求,发送请求到服务器,然后将响应解析为DOM对象。这个过程在不同版本的浏览器中可能略有差异。
|
5天前
|
XML Web App开发 JavaScript
XML DOM 解析器
浏览器内置的XML解析器将XML转换为XML DOM,便于JavaScript操作。通过XMLHttpRequest加载XML文档,如`books.xml`,创建HTTP请求并获取响应,将响应转化为DOM对象。示例展示了在不同浏览器中创建XMLHttpRequest对象并加载XML的过程。
|
7天前
|
Linux 网络安全 Windows
网络安全笔记-day8,DHCP部署_dhcp搭建部署,源码解析
网络安全笔记-day8,DHCP部署_dhcp搭建部署,源码解析
|
8天前
HuggingFace Tranformers 源码解析(4)
HuggingFace Tranformers 源码解析
42 0
|
8天前
HuggingFace Tranformers 源码解析(3)
HuggingFace Tranformers 源码解析
36 0
|
8天前
|
开发工具 git
HuggingFace Tranformers 源码解析(2)
HuggingFace Tranformers 源码解析
12 0
|
8天前
|
并行计算
HuggingFace Tranformers 源码解析(1)
HuggingFace Tranformers 源码解析
19 0

推荐镜像

更多