Xml中SelectSingleNode方法,xpath查找某節點用法


轉自:https://www.cnblogs.com/love201314/p/5589784.html

最常見的XML數據類型有:Element, Attribute,Comment, Text. Element, 指形如<Name>Tom<Name>的節點。它可以包括:Element, Text, Comment, ProcessingInstruction, CDATA, and EntityReference.

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

   Comment,指形如:<!-- my comment --> 的節點。

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

  在XML中,可以用XmlNode對象來參照各種XML數據類型。

 

   2.1 查詢已知絕對路徑的節點(集)

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

  或者

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

 

  以上兩種方法可返回一個NodeList對象,如果要返回單個節點可使用SelectSingleNode方法,該方法如果查詢到一個或多個節點,返回第一個節點;如果沒有查詢的任何節點返回 Nothing。例如:

 

   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 參考數據

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <Company>
 3     <Department>
 4         <Department_Name>Cai WuBu</Department_Name>
 5         <Manager>Zhang Bin</Manager>
 6         <Employees>
 7             <Employee>
 8                 <Employee_ID>12345</Employee_ID>
 9                 <Name>Zhang Bin</Name>
10                 <Gender>male</Gender>
11             </Employee>
12             <Employee>
13                 <Employee_ID>10101</Employee_ID>
14                 <Name>Zhang QI</Name>
15                 <Gender>female</Gender>
16             </Employee>
17             <Employee>
18                 <Employee_ID>10102</Employee_ID>
19                 <Name>Zhang Xia</Name>
20                 <Gender>male</Gender>
21             </Employee>
22             <Employee>
23                 <Employee_ID>10201</Employee_ID>
24                 <Name>ZhangChuang</Name>
25                 <Gender>male</Gender>
26             </Employee>
27             <Employee>
28                 <Employee_ID>10202</Employee_ID>
29                 <Name>Zhang Jun</Name>
30                 <Gender>male</Gender>
31             </Employee>
32         </Employees>
33     </Department>
34     <Department>
35         <Department_Name>KaiFa Bu</Department_Name>
36         <Manager>Wang Bin</Manager>
37         <Employees>
38             <Employee>
39                 <Employee_ID>22345</Employee_ID>
40                 <Name>Wang Bin</Name>
41                 <Gender>male</Gender>
42             </Employee>
43             <Employee>
44                 <Employee_ID>20101</Employee_ID>
45                 <Name>Wang QI</Name>
46                 <Gender>female</Gender>
47             </Employee>
48             <Employee>
49                 <Employee_ID>20102</Employee_ID>
50                 <Name>Wang Xia</Name>
51                 <Gender>male</Gender>
52             </Employee>
53             <Employee>
54                 <Employee_ID>20201</Employee_ID>
55                 <Name>Wang Chuang</Name>
56                 <Gender>male</Gender>
57             </Employee>
58             <Employee>
59                 <Employee_ID>20201</Employee_ID>
60                 <Name>Wang Jun</Name>
61                 <Gender>male</Gender>
62             </Employee>
63         </Employees>
64     </Department>
65 </Company>    

C#用xpath查找某節點

  1 從根節點一直下來的相對路徑才能確定Xpath的寫法。
  2 
  3 /root/<節點1>/<節點2>//<@屬性>
  4 
  5 Xpath是功能很強大的,但是也是相對比較復雜的一門技術,最好還是到博客園上面去專門找一些專業的帖子來看一看,下面是一些簡單的Xpath語法和一個實例,提供給你參考一下
  6 
  7 
  8 <?xml version="1.0" encoding="ISO-8859-1"?>
  9 <catalog>
 10   <cd country="USA">
 11     <title>Empire Burlesque</title>
 12     <artist>Bob Dylan</artist>
 13     <price>10.90</price>
 14   </cd>
 15   <cd country="UK">
 16     <title>Hide your heart</title>
 17     <artist>Bonnie Tyler</artist>
 18     <price>9.90</price>
 19   </cd>
 20   <cd country="USA">
 21     <title>Greatest Hits</title> 
 22     <artist>Dolly Parton</artist> 
 23     <price>9.90</price> 
 24   </cd>
 25 </catalog>
 26 
 27          
 28 定位節點 
 29 XML是樹狀結構,類似檔案系統內數據夾的結構,XPath也類似檔案系統的路徑命名方式。不過XPath 是一種模式(Pattern),可以選出 XML檔案中,路徑符合某個模式的所有節點出來。例如要選catalog底下的cd中所有price元素可以用: 
 30 
 31 
 32 /catalog/cd/price     
 33 
 34 如果XPath的開頭是一個斜線(/)代表這是絕對路徑。如果開頭是兩個斜線(//)表示文件中所有符合模式的元素都會被選出來,即使是處於樹中不同的層級也會被選出來。以下的語法會選出文件中所有叫做cd的元素(在樹中的任何層級都會被選出來): 
 35 
 36 
 37 //cd
 38 
 39 選擇未知的元素 
 40 使用星號(Wildcards,*)可以選擇未知的元素。下面這個語法會選出/catalog/cd 的所有子元素: 
 41 
 42 
 43 /catalog/cd/*
 44 
 45 以下的語法會選出所有catalog的子元素中,包含有price作為子元素的元素。
 46 
 47 
 48 /catalog/*/price
 49 
 50 以下的語法會選出有兩層父節點,叫做price的所有元素。
 51 
 52 
 53 /*/*/price
 54 
 55 以下的語法會選擇出文件中的所有元素。 
 56 
 57 
 58 //*
 59 
 60 要注意的是,想要存取不分層級的元素,XPath語法必須以兩個斜線開頭(//),想要存取未知元素才用星號(*),星號只能代表未知名稱的元素,不能代表未知層級的元素。
 61 
 62 選擇分支 
 63 使用中括號可以選擇分支。以下的語法從catalog的子元素中取出第一個叫做cd的元素。XPath的定義中沒有第0元素這種東西。 
 64 
 65 
 66 /catalog/cd[1]
 67 
 68 以下語法選擇catalog中的最后一個cd元素:(XPathj並沒有定義 first() 這種函式喔,用上例的 [1]就可以取出第一個元素。 
 69 
 70 
 71 /catalog/cd[last()]
 72 
 73 以下語法選出含有price子元素的所有/catalog/cd元素。 
 74 
 75 
 76 /catalog/cd[price]
 77 
 78 以下語法選出price元素的值等於10.90的所有/catalog/cd元素 
 79 
 80 
 81 /catalog/cd[price=10.90]
 82 
 83 以下語法選出price元素的值等於10.90的所有/catalog/cd元素 的price元素 
 84 
 85 
 86 /catalog/cd[price=10.90]/price
 87 
 88 選擇一個以上的路徑 
 89 使用Or操作數(|)就可以選擇一個以上的路徑。例如: 
 90 
 91 
 92 /catalog/cd/title | catalog/cd/artist
 93 
 94 選擇所有title以及artist元素
 95 
 96 
 97 //title | //artist
 98 
 99 選擇所有title以及artist以及price元素
100 
101 
102 //title | //artist | //price
103 
104 選擇屬性 
105 在XPath中,除了選擇元素以外,也可以選擇屬性。屬性都是以@開頭。例如選擇文件中所有叫做country的屬性: 
106 
107 
108 //@country
109          
110 選擇所有含有country這個屬性的cd元素:
111 
112 
113 //cd[@country]
114          
115 以下語法選擇出含有屬性的所有cd元素
116 
117 
118 //cd[@*]
119          
120 以下語法選擇出country屬性值為UK的cd元素
121 
122 
123 //cd[@country='UK']

 

鏈接: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之間的關系

1、XmlElement繼承XmlLinkedNode又繼承XmlNode,所以XmlElement是XmlNode的子集,那么從繼承的關系來說, 

     XmlNode的屬性,XmlElement也可以使用。

2、XmlNode是.Net提供的抽象類,不能直接實例化,只能通過XmlDocument的CreateNode方法來創建,但是

     XmlElement則不需要,可以直接實例化創建

3、為節點添加屬性的時候,可以直接通過XmlElement的SetAttribute來添加,也可以通過XmlNode的Attribute的add方法

     來添加,同樣添加文本節點的時候也是如此

4、XmlDocument是XmlNode的擴展類,包含了很多XmlNode沒有的方法和屬性,我們可以通過它將xml加載到內存中通過

    Dom來處理,也可以通過它來創建節點等

 

下面就來看看如何添加節點和屬性

1、首先我們需要創建一個節點元素,創建的時候我們可以通過XmlDocument的CreateElement來創建,或者是通過

     XmlElement直接實例化,然后通過屬性賦值,比如Name

2、創建一個XmlNode,也就是說創建的節點需要放在什么位置,然后創建的節點加入該XmlNode后面就可以了(可以通過

    XmlNode的AppendChild方法來添加),比如加入根目錄下面:XmlDocument.DocumentElement.PrependChild

    (XmlElement),如果是其他節點下,可以通過Xmldocument的SelectSingleNode("//Titles//Title")來獲得XmlNode

3、添加屬性的時候,可以直接在創建XmlElment的時候,通過XmlElement的SetAttribute來為節點創建屬性,或者是創建

     一個XmlAttribute實例:XmlAttribute  xmlArr=XmlDocument.CreateAttribute("屬性值"),然后通過XmlNode的

    Attributes.add(XmlArribute)來添加

下面來具體看幾個例子吧

1 <?xml version="1.0" encoding="utf-8"?>
2 <Titles>
3   <Title ID="21" Name="王六" />
4   <Title ID="20" Name="王五" />
5   <Title ID="19" Name="李四" />
6   <Title ID="18" Name="張三" />
7   <Title ID="16" Name="asdf" />
8   <Title ID="17" Name="12" />
9 </Titles>

添加方法

 1 protected void Button3_Click(object sender, EventArgs e)
 2     {
 3 
 4         //加載xml文檔
 5         XmlDocument doc = new XmlDocument();
 6         string path = Server.MapPath("~/Title.xml");
 7         doc.Load(path);
 8         //創建節點
 9         XmlElement xmlElement = doc.CreateElement("Title");
10 
11         //添加屬性
12         xmlElement.SetAttribute("ID", "21");
13         xmlElement.SetAttribute("Name","王六");
14         //將節點加入到指定的節點下
15         XmlNode xml = doc.DocumentElement.PrependChild(xmlElement);
16         doc.Save(path);
17     }

或者是

 1 protected void Button3_Click(object sender, EventArgs e)
 2     {
 3         XmlDocument doc = new XmlDocument();
 4         string path = Server.MapPath("~/Title.xml");
 5         doc.Load(path);
 6         //創建節點
 7         XmlElement xmlElement = doc.CreateElement("Title");
 8         ////將節點加入到指定的節點下
 9         XmlNode xmlTitle = doc.DocumentElement.PrependChild(xmlElement);
10         //為該節點加入屬性
11         XmlAttribute xmlID = doc.CreateAttribute("ID");
12         xmlID.Value = "22";
13         xmlTitle.Attributes.Append(xmlID);
14 
15         XmlAttribute xmlName = doc.CreateAttribute("Name");
16         xmlName.InnerText = "小三";
17         xmlTitle.Attributes.Append(xmlName);
18 
19         doc.Save(path);
20     }

 

如果不需要創建節點,直接通過SelectSingleNode(string path)來獲取XmlNode,然后再添加屬性或者文本節點等,如下:

 1 protected void Button2_Click(object sender, EventArgs e)
 2     {
 3         XmlDocument doc = new XmlDocument();
 4         string path = Server.MapPath("~/XMLFile.xml");
 5         doc.Load(path);
 6         //創建一個book節點
 7         XmlNode xml = doc.SelectSingleNode("//TiTles//TiTle");
 8         XmlAttribute xmlAttribute = doc.CreateAttribute("ss");
 9         xmlAttribute.InnerText = "bb";
10         xml.Attributes.Append(xmlAttribute);
11         doc.Save(path);
12     }

大概過程就是

1、通過XmlDocument加載xml文件到內存

2、創建XmlElement節點(可以通過SetAttribute添加屬性)

3、創建和查找XmlNode以確保要放置的位置,將XmlElement添加到XmlNode中

4、如果沒有通過SetAttribute來添加屬性,后面可以創建XmlArribute來完成屬性的添加

5、最后重新保存Xml:XmlDocument.save(xpath);

 

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM