在C#.net中如何操作XML
需要添加的命名空间:
using System.Xml;
定义几个公共对象:
XmlDocument xmldoc ;
XmlNode xmlnode ;
XmlElement xmlelem ;
1,创建到服务器同名目录下的xml文件:
方法一:
Code
1 xmldoc = new XmlDocument ( ) ;
2 //加入XML的声明段落
3 xmlnode = xmldoc.CreateNode ( XmlNodeType.XmlDeclaration , "" , "" ) ;
4 xmldoc.AppendChild ( xmlnode ) ;
5 //加入一个根元素
6 xmlelem = xmldoc.CreateElement ( "" , "Employees" , "" ) ;
7 xmldoc.AppendChild ( xmlelem ) ;
8 //加入另外一个元素
9 for(int i=1;i<3;i )
10 {
11
12 XmlNode root=xmldoc.SelectSingleNode("Employees");//查找<Employees>
13 XmlElement xe1=xmldoc.CreateElement("Node");//创建一个<Node>节点
14 xe1.SetAttribute("genre","李赞红");//设置该节点genre属性
15 xe1.SetAttribute("ISBN","2-3631-4");//设置该节点ISBN属性
16
17 XmlElement xesub1=xmldoc.CreateElement("title");
18 xesub1.InnerText="CS从入门到精通";//设置文本节点
19 xe1.AppendChild(xesub1);//添加到<Node>节点中
20 XmlElement xesub2=xmldoc.CreateElement("author");
21 xesub2.InnerText="候捷";
22 xe1.AppendChild(xesub2);
23 XmlElement xesub3=xmldoc.CreateElement("price");
24 xesub3.InnerText="58.3";
25 xe1.AppendChild(xesub3);
26
27 root.AppendChild(xe1);//添加到<Employees>节点中
28 }
29 //保存创建好的XML文档
30 xmldoc.Save ( Server.MapPath("data.xml") ) ;
//////////////////////////////////////////////////////////////////////////////////////
结果:在同名目录下生成了名为data.xml的文件,内容如下
1
<?
xml version="1.0"
?>
2
<
Employees
>
3
<
Node
genre
="李赞红"
ISBN
="2-3631-4"
>
4
<
title
>
CS从入门到精通
</
title
>
5
<
author
>
候捷
</
author
>
6
<
price
>
58.3
</
price
>
7
</
Node
>
8
<
Node
genre
="李赞红"
ISBN
="2-3631-4"
>
9
<
title
>
CS从入门到精通
</
title
>
10
<
author
>
候捷
</
author
>
11
<
price
>
58.3
</
price
>
12
</
Node
>
13
</
Employees
>
方法二:
Code
1 XmlTextWriter xmlWriter;
2 string strFilename = Server.MapPath("data1.xml") ;
3
4 xmlWriter = new XmlTextWriter(strFilename,Encoding.Default);//创建一个xml文档
5 xmlWriter.Formatting = Formatting.Indented;
6 xmlWriter.WriteStartDocument();
7 xmlWriter.WriteStartElement("Employees");
8
9 xmlWriter.WriteStartElement("Node");
10 xmlWriter.WriteAttributeString("genre","李赞红");
11 xmlWriter.WriteAttributeString("ISBN","2-3631-4");
12
13 xmlWriter.WriteStartElement("title");
14 xmlWriter.WriteString("CS从入门到精通");
15 xmlWriter.WriteEndElement();
16
17 xmlWriter.WriteStartElement("author");
18 xmlWriter.WriteString("候捷");
19
20 xmlWriter.WriteEndElement();
21
22
23
24 xmlWriter.WriteStartElement("price");
25 xmlWriter.WriteString("58.3");
26 xmlWriter.WriteEndElement();
27
28 xmlWriter.WriteEndElement();
29
30 xmlWriter.Close();
31
32
//////////////////////////////////////////////////////////////////////////////////////
结果:
1
<?
xml version="1.0" encoding="gb2312"
?>
2
<
Employees
>
3
<
Node
genre
="李赞红"
ISBN
="2-3631-4"
>
4
<
title
>
CS从入门到精通
</
title
>
5
<
author
>
候捷
</
author
>
6
<
price
>
58.3
</
price
>
7
</
Node
>
8
</
Employees
>
2,添加一个结点:
Code
1 XmlDocument xmlDoc=new XmlDocument();
2 xmlDoc.Load(Server.MapPath("data.xml"));
3 XmlNode root=xmlDoc.SelectSingleNode("Employees");//查找<Employees>
4 XmlElement xe1=xmlDoc.CreateElement("Node");//创建一个<Node>节点
5 xe1.SetAttribute("genre","张三");//设置该节点genre属性
6 xe1.SetAttribute("ISBN","1-1111-1");//设置该节点ISBN属性
7
8 XmlElement xesub1=xmlDoc.CreateElement("title");
9 xesub1.InnerText="C#入门帮助";//设置文本节点
10 xe1.AppendChild(xesub1);//添加到<Node>节点中
11 XmlElement xesub2=xmlDoc.CreateElement("author");
12 xesub2.InnerText="高手";
13 xe1.AppendChild(xesub2);
14 XmlElement xesub3=xmlDoc.CreateElement("price");
15 xesub3.InnerText="158.3";
16 xe1.AppendChild(xesub3);
17
18 root.AppendChild(xe1);//添加到<Employees>节点中
19 xmlDoc.Save ( Server.MapPath("data.xml") );
20
//////////////////////////////////////////////////////////////////////////////////////
结果:在xml原有的内容里添加了一个结点,内容如下,
1
<?
xml version="1.0"
?>
2
<
Employees
>
3
<
Node
genre
="李赞红"
ISBN
="2-3631-4"
>
4
<
title
>
CS从入门到精通
</
title
>
5
<
author
>
候捷
</
author
>
6
<
price
>
58.3
</
price
>
7
</
Node
>
8
<
Node
genre
="李赞红"
ISBN
="2-3631-4"
>
9
<
title
>
CS从入门到精通
</
title
>
10
<
author
>
候捷
</
author
>
11
<
price
>
58.3
</
price
>
12
</
Node
>
13
<
Node
genre
="张三"
ISBN
="1-1111-1"
>
14
<
title
>
C#入门帮助
</
title
>
15
<
author
>
高手
</
author
>
16
<
price
>
158.3
</
price
>
17
</
Node
>
18
</
Employees
>
3,修改结点的值(属性和子结点):
Code
1 XmlDocument xmlDoc=new XmlDocument();
2 xmlDoc.Load( Server.MapPath("data.xml") );
3
4 XmlNodeList nodeList=xmlDoc.SelectSingleNode("Employees").ChildNodes;//获取Employees节点的所有子节点
5
6 foreach(XmlNode xn in nodeList)//遍历所有子节点
7 {
8 XmlElement xe=(XmlElement)xn;//将子节点类型转换为XmlElement类型
9 if(xe.GetAttribute("genre")=="张三")//如果genre属性值为“张三”
10
11 {
12 xe.SetAttribute("genre","update张三");//则修改该属性为“update张三”
13
14
15
16 XmlNodeList nls=xe.ChildNodes;//继续获取xe子节点的所有子节点
17 foreach(XmlNode xn1 in nls)//遍历
18 {
19 XmlElement xe2=(XmlElement)xn1;//转换类型
20 if(xe2.Name=="author")//如果找到
21 {
22 xe2.InnerText="亚胜";//则修改
23 }
24 }
25 }
26 }
27 xmlDoc.Save( Server.MapPath("data.xml") );//保存。
//////////////////////////////////////////////////////////////////////////////////////
结果:将原来的所有结点的信息都修改了,xml的内容如下,
1
<?
xml version="1.0"
?>
2
<
Employees
>
3
<
Node
genre
="李赞红"
ISBN
="2-3631-4"
>
4
<
title
>
CS从入门到精通
</
title
>
5
<
author
>
候捷
</
author
>
6
<
price
>
58.3
</
price
>
7
</
Node
>
8
<
Node
genre
="李赞红"
ISBN
="2-3631-4"
>
9
<
title
>
CS从入门到精通
</
title
>
10
<
author
>
候捷
</
author
>
11
<
price
>
58.3
</
price
>
12
</
Node
>
13
<
Node
genre
="update张三"
ISBN
="1-1111-1"
>
14
<
title
>
C#入门帮助
</
title
>
15
<
author
>
亚胜
</
author
>
16
<
price
>
158.3
</
price
>
17
</
Node
>
18
</
Employees
>
4,修改结点(添加结点的属性和添加结点的自结点):
Code
1 XmlDocument xmlDoc=new XmlDocument();
2 xmlDoc.Load( Server.MapPath("data.xml") );
3
4 XmlNodeList nodeList=xmlDoc.SelectSingleNode("Employees").ChildNodes;//获取Employees节点的所有子节点
5
6 foreach(XmlNode xn in nodeList)
7 {
8 XmlElement xe=(XmlElement)xn;
9 xe.SetAttribute("test","111111");
10
11 XmlElement xesub=xmlDoc.CreateElement("flag");
12 xesub.InnerText="1";
13 xe.AppendChild(xesub);
14 }
15 xmlDoc.Save( Server.MapPath("data.xml") );
//////////////////////////////////////////////////////////////////////////////////////
结果:每个结点的属性都添加了一个,子结点也添加了一个,内容如下,
1
<?
xml version="1.0"
?>
2
<
Employees
>
3
<
Node
genre
="李赞红"
ISBN
="2-3631-4"
test
="111111"
>
4
<
title
>
CS从入门到精通
</
title
>
5
<
author
>
候捷
</
author
>
6
<
price
>
58.3
</
price
>
7
<
flag
>
1
</
flag
>
8
</
Node
>
9
<
Node
genre
="李赞红"
ISBN
="2-3631-4"
test
="111111"
>
10
<
title
>
CS从入门到精通
</
title
>
11
<
author
>
候捷
</
author
>
12
<
price
>
58.3
</
price
>
13
<
flag
>
1
</
flag
>
14
</
Node
>
15
<
Node
genre
="update张三"
ISBN
="1-1111-1"
test
="111111"
>
16
<
title
>
C#入门帮助
</
title
>
17
<
author
>
亚胜
</
author
>
18
<
price
>
158.3
</
price
>
19
<
flag
>
1
</
flag
>
20
</
Node
>
21
</
Employees
>
5,删除结点中的某一个属性:
Code
1 XmlDocument xmlDoc=new XmlDocument();
2 xmlDoc.Load( Server.MapPath("data.xml") );
3 XmlNodeList xnl=xmlDoc.SelectSingleNode("Employees").ChildNodes;
4 foreach(XmlNode xn in xnl)
5 {
6 XmlElement xe=(XmlElement)xn;
7 xe.RemoveAttribute("genre");//删除genre属性
8
9
10
11 XmlNodeList nls=xe.ChildNodes;//继续获取xe子节点的所有子节点
12 foreach(XmlNode xn1 in nls)//遍历
13 {
14 XmlElement xe2=(XmlElement)xn1;//转换类型
15 if(xe2.Name=="flag")//如果找到
16 {
17 xe.RemoveChild(xe2);//则删除
18 }
19 }
20 }
21 xmlDoc.Save( Server.MapPath("data.xml") );
//////////////////////////////////////////////////////////////////////////////////////]
结果:删除了结点的一个属性和结点的一个子结点,内容如下,
1
<?
xml version="1.0"
?>
2
<
Employees
>
3
<
Node
ISBN
="2-3631-4"
test
="111111"
>
4
<
title
>
CS从入门到精通
</
title
>
5
<
author
>
候捷
</
author
>
6
<
price
>
58.3
</
price
>
7
</
Node
>
8
<
Node
ISBN
="2-3631-4"
test
="111111"
>
9
<
title
>
CS从入门到精通
</
title
>
10
<
author
>
候捷
</
author
>
11
<
price
>
58.3
</
price
>
12
</
Node
>
13
<
Node
ISBN
="1-1111-1"
test
="111111"
>
14
<
title
>
C#入门帮助
</
title
>
15
<
author
>
亚胜
</
author
>
16
<
price
>
158.3
</
price
>
17
</
Node
>
18
</
Employees
>
6,删除结点:
Code
1 XmlDocument xmlDoc=new XmlDocument();
2 xmlDoc.Load( Server.MapPath("data.xml") );
3 XmlNode root=xmlDoc.SelectSingleNode("Employees");
4 XmlNodeList xnl=xmlDoc.SelectSingleNode("Employees").ChildNodes;
5 for(int i=0;i<xnl.Count;i )
6 {
7 XmlElement xe=(XmlElement)xnl.Item(i);
8 if(xe.GetAttribute("genre")=="张三")
9 {
10 root.RemoveChild(xe);
11 if(i<xnl.Count)i=i-1;
12 }
13 }
14 xmlDoc.Save( Server.MapPath("data.xml") );
结果:删除了符合条件的所有结点,原来的内容:
1
<?
xml version="1.0"
?>
2
<
Employees
>
3
<
Node
genre
="李赞红"
ISBN
="2-3631-4"
>
4
<
title
>
CS从入门到精通
</
title
>
5
<
author
>
候捷
</
author
>
6
<
price
>
58.3
</
price
>
7
</
Node
>
8
<
Node
genre
="李赞红"
ISBN
="2-3631-4"
>
9
<
title
>
CS从入门到精通
</
title
>
10
<
author
>
候捷
</
author
>
11
<
price
>
58.3
</
price
>
12
</
Node
>
13
<
Node
genre
="张三"
ISBN
="1-1111-1"
>
14
<
title
>
C#入门帮助
</
title
>
15
<
author
>
高手
</
author
>
16
<
price
>
158.3
</
price
>
17
</
Node
>
18
19
<
Node
genre
="张三"
ISBN
="1-1111-1"
>
20
<
title
>
C#入门帮助
</
title
>
21
<
author
>
高手
</
author
>
22
<
price
>
158.3
</
price
>
23
</
Node
>
24
</
Employees
>
删除后的内容:
1
<?
xml version="1.0"
?>
2
<
Employees
>
3
<
Node
genre
="李赞红"
ISBN
="2-3631-4"
>
4
<
title
>
CS从入门到精通
</
title
>
5
<
author
>
候捷
</
author
>
6
<
price
>
58.3
</
price
>
7
</
Node
>
8
<
Node
genre
="李赞红"
ISBN
="2-3631-4"
>
9
<
title
>
CS从入门到精通
</
title
>
10
<
author
>
候捷
</
author
>
11
<
price
>
58.3
</
price
>
12
</
Node
>
13
</
Employees
>