在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
>