C#操作xml

1.1. XML 文档操作

1.1 加载一个XML文档

Dim objDoc As New XmlDocument()

'-- Load xml document Sample.xml

objDoc.Load("Sample.xml")

1.2 加载一个XML数据

Dim objDoc As New XmlDocument()

Dim strXML As String

strXML = "<Employees><Employee

'-- Load xml data

objDoc.Load(strXML)

1.3 保存文档

'—Save xml document

objDoc.Save("Sample.xml")

2 XML 数据的查询

最常见的XML数据类型有:Element, Attribute,Comment, Text.

Element, 指形如<Name>Tom<Name>的节点。它可以包括:Element, Text, Comment, ProcessingInstruction, CDATA, and EntityReference.

Attribute, 指在<Employee id=”12345”>中的粗体部分。

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/@]/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>

2.

我用的是一种很笨的方法,但可以帮助初学者了解访问XML节点的过程。

已知有一个XML文件(bookstore.xml)如下:

<?xml version="1.0" encoding="gb2312"?>

<bookstore>

<book genre="fantasy" ISBN="2-3631-4">

<title>Oberon's Legacy</title>

<author>Corets, Eva</author>

<price>5.95</price>

</book>

</bookstore>

1、往<bookstore>节点中插入一个<book>节点:

XmlDocument xmlDoc=new XmlDocument();

xmlDoc.Load("bookstore.xml");

XmlNode root=xmlDoc.SelectSingleNode("bookstore");//查找<bookstore>

XmlElement xe1=xmlDoc.CreateElement("book");//创建一个<book>节点

xe1.SetAttribute("genre","李赞红");//设置该节点genre属性

xe1.SetAttribute("ISBN","2-3631-4");//设置该节点ISBN属性

XmlElement xesub1=xmlDoc.CreateElement("title");

xesub1.InnerText="CS从入门到精通";//设置文本节点

xe1.AppendChild(xesub1);//添加到<book>节点中

XmlElement xesub2=xmlDoc.CreateElement("author");

xesub2.InnerText="候捷";

xe1.AppendChild(xesub2);

XmlElement xesub3=xmlDoc.CreateElement("price");

xesub3.InnerText="58.3";

xe1.AppendChild(xesub3);

root.AppendChild(xe1);//添加到<bookstore>节点中

xmlDoc.Save("bookstore.xml");

//===============================================

结果为:

<?xml version="1.0" encoding="gb2312"?>

<bookstore>

<book genre="fantasy" ISBN="2-3631-4">

<title>Oberon's Legacy</title>

<author>Corets, Eva</author>

<price>5.95</price>

</book>

<book genre="李赞红" ISBN="2-3631-4">

<title>CS从入门到精通</title>

<author>候捷</author>

<price>58.3</price>

</book>

</bookstore>

2、修改节点:将genre属性值为“李赞红“的节点的genre值改为“update李赞红”,将该节点的子节点<author>的文本修改为“亚胜”。

XmlNodeList nodeList=xmlDoc.SelectSingleNode("bookstore").ChildNodes;//获取bookstore节点的所有子节点

foreach(XmlNode xn in nodeList)//遍历所有子节点

{

XmlElement xe=(XmlElement)xn;//将子节点类型转换为XmlElement类型

if(xe.GetAttribute("genre")=="李赞红")//如果genre属性值为“李赞红”

{

xe.SetAttribute("genre","update李赞红");//则修改该属性为“update李赞红”

XmlNodeList nls=xe.ChildNodes;//继续获取xe子节点的所有子节点

foreach(XmlNode xn1 in nls)//遍历

{

XmlElement xe2=(XmlElement)xn1;//转换类型

if(xe2.Name=="author")//如果找到

{

xe2.InnerText="亚胜";//则修改

break;//找到退出来就可以了

}

}

break;

}

}

xmlDoc.Save("bookstore.xml");//保存。

//==================================================

最后结果为:

<?xml version="1.0" encoding="gb2312"?>

<bookstore>

<book genre="fantasy" ISBN="2-3631-4">

<title>Oberon's Legacy</title>

<author>Corets, Eva</author>

<price>5.95</price>

</book>

<book genre="update李赞红" ISBN="2-3631-4">

<title>CS从入门到精通</title>

<author>亚胜</author>

<price>58.3</price>

</book>

</bookstore>

3、删除 <book genre="fantasy" ISBN="2-3631-4">节点的genre属性,删除 <book genre="update李赞红" ISBN="2-3631-4">节点。

XmlNodeList xnl=xmlDoc.SelectSingleNode("bookstore").ChildNodes;

foreach(XmlNode xn in xnl)

{

XmlElement xe=(XmlElement)xn;

if(xe.GetAttribute("genre")=="fantasy")

{

xe.RemoveAttribute("genre");//删除genre属性

}

else if(xe.GetAttribute("genre")=="update李赞红")

{

xe.RemoveAll();//删除该节点的全部内容

}

}

xmlDoc.Save("bookstore.xml");

//===========================================

最后结果为:

<?xml version="1.0" encoding="gb2312"?>

<bookstore>

<book ISBN="2-3631-4">

<title>Oberon's Legacy</title>

<author>Corets, Eva</author>

<price>5.95</price>

</book>

<book>

</book>

</bookstore>

4、显示所有数据。

XmlNode xn=xmlDoc.SelectSingleNode("bookstore");

XmlNodeList xnl=xn.ChildNodes;

foreach(XmlNode xnf in xnl)

{

XmlElement xe=(XmlElement)xnf;

Console.WriteLine(xe.GetAttribute("genre"));//显示属性值

Console.WriteLine(xe.GetAttribute("ISBN"));

XmlNodeList xnf1=xe.ChildNodes;

foreach(XmlNode xn2 in xnf1)

{

Console.WriteLine(xn2.InnerText);//显示子节点点文本

}

}