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

相關文章
相關標籤/搜索