Xml中SelectSingleNode方法,xpath查找某节点用法

 最多见的XML数据类型有:Element, Attribute,Comment, Text. Element, 指形如<Name>Tom<Name>的节点。它能够包括:Element, Text, Comment, ProcessingInstruction, CDATA, and EntityReference.html

   Attribute, 指在<Employee >中的粗体部分。ide

   Comment,指形如:<!-- my comment --> 的节点。post

   Text,指在<Name>Tom<Name>的粗体部分。ui

  在XML中,能够用XmlNode对象来参照各类XML数据类型。url

 

   2.1 查询已知绝对路径的节点(集)spa

   objNodeList = objDoc.SelectNodes(“Company/Department/Employees/Employee”).net

  或者3d

   objNodeList = objNode.SelectNodes(“/Company/Department/Employees/Employee”)code

 

  以上两种方法可返回一个NodeList对象,若是要返回单个节点可以使用SelectSingleNode方法,该方法若是查询到一个或多个节点,返回第一个节点;若是没有查询的任何节点返回 Nothing。例如:xml

 

   objNode = objNode.SelectSingleNode(“/Company/Department/Employees/Employee”)

   If Not (objNode is Nothing) then

   ‘- Do process

   End If

 

   2.2 查询已知相对路径的节点(集)

 

  可以使用相似于文件路径的相对路径的方式来查询XML的数据

   objNode = objDoc.SelectSingleNode(“Company/Department”)

   objNodeList = objNode.SelectNodes(“../Department)

   objNode = objNode.SelectNode(“Employees/Employee”)

 

   2.3 查询已知元素名的节点(集)

 

  在使用不规则的层次文档时,因为不知道中间层次的元素名,可以使用//符号来越过中间的节点,查询其子,孙或多层次下的其余全部元素。例如:

   objNodeList = objDoc.SelectNodes(“Company//Employee”)

 

   2.4 查询属性(attribute)节点

 

  以上的各类方法都返回元素(element)节点(集),返回属性(attribute),只须要采用相应的方法,在属性名前加一个@符号便可,例如:

   objNodeList = objDoc.SelectNodes(“Company/Department/Employees/Employee/@id”)

   objNodeList = objDoc.SelectNodes(“Company//@id”)

 

   2.5 查询Text节点

 

  使用text()来获取Text节点。

   objNode = objDoc.SelectSingleNode(“Company/Department/Deparmt_Name/text()”)

 

   2.6 查询特定条件的节点

 

  使用[]符号来查询特定条件的节点。例如:

 

   a. 返回id号为 10102的Employee节点

   objNode = objDoc.SelectSingleNode(“Company/Department/Employees/Employee[@id=’10102’]”)

 

   b. 返回Name为Zhang Qi的Name 节点

   objNode = objDoc.SelectSingleNode(“Company/Department/Employees/Employee/Name[text()=’Zhang Qi’]”)

 

   c. 返回部门含有职员22345的部门名称节点

   objNode = objDoc.SelectSingleNode("Company/Department[Employees/Employee/@id='22345']/Department_Name")

 

   2.7 查询多重模式的节点

 

  使用 | 符号能够得到多重模式的节点。例如:

   objNodeList = objDoc.SelectNodes(“Company/Department/Department_Name | Company/Department/Manager”)

 

   2.8 查询任意子节点

 

  使用*符号能够返回当前节点的全部子节点。

   objNodeList = objDoc.SelectNodes(“Company/*/Manager)

  或者

   objNodeList = objNode.ChildNodes 

 

   3 XML数据的编辑

 

   3.1 增长一个元素的属性(attribute)节点

   Dim objNodeAttr As XmlNode

   objNodeAttr = objDoc.CreateAttribute("id", Nothing)

   objNodeAttr.InnerXml = "101"

   objNode.Attributes.Append(objNodeAttr)

 

   3.2 删除一个元素的属性

   objNode.Attributes.Remove(objNodeAttr)

 

   3.3 增长一个子元素(Element)

   Dim objNodeChild As XmlNode

   objNodeChild = objDoc.CreateElement(Nothing, "ID", Nothing)

   objNodeChild.InnerXml = "101"

   objNode.AppendChild(objNodeChild)

 

   3.4 删除一个子元素

   objNode.RemoveChild(objNodeChild)

 

   3.5 替换一个子元素

   objNOde.ReplaceChild(newChild,oldChild) 

 4 参考数据

 

<?xml version="1.0" encoding="UTF-8"?>   <Company>   <Department >   <Department_Name>Cai WuBu</Department_Name>   <Manager>Zhang Bin</Manager>   <Employees>   <Employee >   <Employee_ID>12345</Employee_ID>   <Name>Zhang Bin</Name>   <Gender>male</Gender>   </Employee>   <Employee >   <Employee_ID>10101</Employee_ID>   <Name>Zhang QI</Name>   <Gender>female</Gender>   </Employee>   <Employee >   <Employee_ID>10102</Employee_ID>   <Name>Zhang Xia</Name>   <Gender>male</Gender>   </Employee>   <Employee >   <Employee_ID>10201</Employee_ID>   <Name>ZhangChuang</Name>   <Gender>male</Gender>   </Employee>   <Employee >   <Employee_ID>10202</Employee_ID>   <Name>Zhang Jun</Name>   <Gender>male</Gender>   </Employee>   </Employees>   </Department>   <Department >   <Department_Name>KaiFa Bu</Department_Name>   <Manager>Wang Bin</Manager>   <Employees>   <Employee >   <Employee_ID>22345</Employee_ID>   <Name>Wang Bin</Name>   <Gender>male</Gender>   </Employee>   <Employee >   <Employee_ID>20101</Employee_ID>   <Name>Wang QI</Name>   <Gender>female</Gender>   </Employee>   <Employee >   <Employee_ID>20102</Employee_ID>   <Name>Wang Xia</Name>   <Gender>male</Gender>   </Employee>   <Employee >   <Employee_ID>20201</Employee_ID>   <Name>Wang Chuang</Name>   <Gender>male</Gender>   </Employee>   <Employee >   <Employee_ID>20201</Employee_ID>   <Name>Wang Jun</Name>   <Gender>male</Gender>   </Employee>   </Employees>   </Department>   </Company>
View Code

 

C#用xpath查找某节点

从根节点一直下来的相对路径才能肯定Xpath的写法。

/root/<节点1>/<节点2>//<@属性>

Xpath是功能很强大的,可是也是相对比较复杂的一门技术,最好仍是到博客园上面去专门找一些专业的帖子来看一看,下面是一些简单的Xpath语法和一个实例,提供给你参考一下


<?xml version="1.0" encoding="ISO-8859-1"?>
<catalog>
  <cd country="USA">
    <title>Empire Burlesque</title>
    <artist>Bob Dylan</artist>
    <price>10.90</price>
  </cd>
  <cd country="UK">
    <title>Hide your heart</title>
    <artist>Bonnie Tyler</artist>
    <price>9.90</price>
  </cd>
  <cd country="USA">
    <title>Greatest Hits</title> 
    <artist>Dolly Parton</artist> 
    <price>9.90</price> 
  </cd>
</catalog>

         
定位节点 
XML是树状结构,相似档案系统内数据夹的结构,XPath也相似档案系统的路径命名方式。不过XPath 是一种模式(Pattern),能够选出 XML档案中,路径符合某个模式的全部节点出来。例如要选catalog底下的cd中全部price元素能够用: 


/catalog/cd/price     

若是XPath的开头是一个斜线(/)表明这是绝对路径。若是开头是两个斜线(//)表示文件中全部符合模式的元素都会被选出来,即便是处于树中不一样的层级也会被选出来。如下的语法会选出文件中全部叫作cd的元素(在树中的任何层级都会被选出来): 


//cd

选择未知的元素 
使用星号(Wildcards,*)能够选择未知的元素。下面这个语法会选出/catalog/cd 的全部子元素: 


/catalog/cd/*

如下的语法会选出全部catalog的子元素中,包含有price做为子元素的元素。


/catalog/*/price

如下的语法会选出有两层父节点,叫作price的全部元素。


/*/*/price

如下的语法会选择出文件中的全部元素。 


//*

要注意的是,想要存取不分层级的元素,XPath语法必须以两个斜线开头(//),想要存取未知元素才用星号(*),星号只能表明未知名称的元素,不能表明未知层级的元素。

选择分支 
使用中括号能够选择分支。如下的语法从catalog的子元素中取出第一个叫作cd的元素。XPath的定义中没有第0元素这种东西。 


/catalog/cd[1]

如下语法选择catalog中的最后一个cd元素:(XPathj并无定义 first() 这种函式喔,用上例的 [1]就能够取出第一个元素。 


/catalog/cd[last()]

如下语法选出含有price子元素的全部/catalog/cd元素。 


/catalog/cd[price]

如下语法选出price元素的值等于10.90的全部/catalog/cd元素 


/catalog/cd[price=10.90]

如下语法选出price元素的值等于10.90的全部/catalog/cd元素 的price元素 


/catalog/cd[price=10.90]/price

选择一个以上的路径 
使用Or操做数(|)就能够选择一个以上的路径。例如: 


/catalog/cd/title | catalog/cd/artist

选择全部title以及artist元素


//title | //artist

选择全部title以及artist以及price元素


//title | //artist | //price

选择属性 
在XPath中,除了选择元素之外,也能够选择属性。属性都是以@开头。例如选择文件中全部叫作country的属性: 


//@country
         
选择全部含有country这个属性的cd元素:


//cd[@country]
         
如下语法选择出含有属性的全部cd元素


//cd[@*]
         
如下语法选择出country属性值为UK的cd元素


//cd[@country='UK'] 
View Code

 

连接:http://blog.csdn.net/whuarui2010/article/details/8012856

http://www.cnblogs.com/timy/archive/2010/05/18/1738438.html

http://www.jb51.net/article/35568.htm

 

Xml文档添加节点和属性   转:http://www.cnblogs.com/shuang121/archive/2011/02/24/1963796.html

在实际的应用开发中须要咱们对xml进行添加节点和属性,动态的去完成,在这以前,先看看XmlNode和XmlElement之间的关系

一、XmlElement继承XmlLinkedNode又继承XmlNode,因此XmlElement是XmlNode的子集,那么从继承的关系来讲, 

     XmlNode的属性,XmlElement也可使用。

二、XmlNode是.Net提供的抽象类,不能直接实例化,只能经过XmlDocument的CreateNode方法来建立,可是

     XmlElement则不须要,能够直接实例化建立

三、为节点添加属性的时候,能够直接经过XmlElement的SetAttribute来添加,也能够经过XmlNode的Attribute的add方法

     来添加,一样添加文本节点的时候也是如此

四、XmlDocument是XmlNode的扩展类,包含了不少XmlNode没有的方法和属性,咱们能够经过它将xml加载到内存中经过

    Dom来处理,也能够经过它来建立节点等

 

下面就来看看如何添加节点和属性

一、首先咱们须要建立一个节点元素,建立的时候咱们能够经过XmlDocument的CreateElement来建立,或者是经过

     XmlElement直接实例化,而后经过属性赋值,好比Name

二、建立一个XmlNode,也就是说建立的节点须要放在什么位置,而后建立的节点加入该XmlNode后面就能够了(能够经过

    XmlNode的AppendChild方法来添加),好比加入根目录下面:XmlDocument.DocumentElement.PrependChild

    (XmlElement),若是是其余节点下,能够经过Xmldocument的SelectSingleNode("//Titles//Title")来得到XmlNode

三、添加属性的时候,能够直接在建立XmlElment的时候,经过XmlElement的SetAttribute来为节点建立属性,或者是建立

     一个XmlAttribute实例:XmlAttribute  xmlArr=XmlDocument.CreateAttribute("属性值"),而后经过XmlNode的

    Attributes.add(XmlArribute)来添加

 

下面来具体看几个例子吧

<?xml version="1.0" encoding="utf-8"?> <Titles> <Title ID="21" Name="王六" /> <Title ID="20" Name="王五" /> <Title ID="19" Name="李四" /> <Title ID="18" Name="张三" /> <Title ID="16" Name="asdf" /> <Title ID="17" Name="12" /> </Titles>
View Code

 

添加方法

 

protected void Button3_Click(object sender, EventArgs e) { //加载xml文档 XmlDocument doc = new XmlDocument(); string path = Server.MapPath("~/Title.xml"); doc.Load(path); //建立节点 XmlElement xmlElement = doc.CreateElement("Title"); //添加属性 xmlElement.SetAttribute("ID", "21"); xmlElement.SetAttribute("Name","王六"); //将节点加入到指定的节点下 XmlNode xml = doc.DocumentElement.PrependChild(xmlElement); doc.Save(path); }
View Code

 

或者是

protected void Button3_Click(object sender, EventArgs e) { XmlDocument doc = new XmlDocument(); string path = Server.MapPath("~/Title.xml"); doc.Load(path); //建立节点 XmlElement xmlElement = doc.CreateElement("Title"); ////将节点加入到指定的节点下 XmlNode xmlTitle = doc.DocumentElement.PrependChild(xmlElement); //为该节点加入属性 XmlAttribute xmlID = doc.CreateAttribute("ID"); xmlID.Value = "22"; xmlTitle.Attributes.Append(xmlID); XmlAttribute xmlName = doc.CreateAttribute("Name"); xmlName.InnerText = "小三"; xmlTitle.Attributes.Append(xmlName); doc.Save(path); }
View Code

 

若是不须要建立节点,直接经过SelectSingleNode(string path)来获取XmlNode,而后再添加属性或者文本节点等,以下:

  

protected void Button2_Click(object sender, EventArgs e) { XmlDocument doc = new XmlDocument(); string path = Server.MapPath("~/XMLFile.xml"); doc.Load(path); //建立一个book节点 XmlNode xml = doc.SelectSingleNode("//TiTles//TiTle"); XmlAttribute xmlAttribute = doc.CreateAttribute("ss"); xmlAttribute.InnerText = "bb"; xml.Attributes.Append(xmlAttribute); doc.Save(path); }
View Code

 

大概过程就是

一、经过XmlDocument加载xml文件到内存

二、建立XmlElement节点(能够经过SetAttribute添加属性)

三、建立和查找XmlNode以确保要放置的位置,将XmlElement添加到XmlNode中

四、若是没有经过SetAttribute来添加属性,后面能够建立XmlArribute来完成属性的添加

五、最后从新保存Xml:XmlDocument.save(xpath);

 

转:http://www.cnblogs.com/shuang121/archive/2011/02/24/1963796.html

相关文章
相关标签/搜索