转自: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