C#使用XmlDocument操作XML进行查询、增加、修改、删除、保存应用的实例(转载)

在.NET中使用DataSet来获取XML数据与保存XML数据很简单,很好用,不过有一些复杂点的XML结构,使用DataSet来操作就没有XmlDocument来操作这么好用了,所以本文在C#使用XmlDocument来操作XML的查询、增加、修改、删除、保存的基本操作。

下面看实例:

XML文件:books.xml
1<?xml version="1.0" encoding="UTF-8"?>
2<books>
3 <book> //这里没有id 下面代码会增加
4 <name>哈里波特</name>
5 <price>10</price>
6 <memo>这是一本很好看的书。</memo>
7 </book>
8 <book id="B02">
9 <name>三国演义</name>
10 <price>10</price>
11 <memo>四大名著之一。</memo>
12 </book>
13 <book id="B03">
14 <name>水浒</name>
15 <price>6</price>
16 <memo>四大名著之一。</memo>
17 </book>
18 <book id="B04">
19 <name>红楼</name>
20 <price>5</price>
21 <memo>四大名著之一。</memo>
22 </book>
23</books>


下面是C#代码:
1eusing System;
2using System.Collections.Generic;
3using System.Text;
4using System.Xml;
5
6namespace TestXml
7 {
8 class Program
9 {
10 static void Main(string[] args)
11 {

// XML表示Dom结构中的元素.XmlElement类的constructor 是protected,所以要通过XmlDocument().createElement()来实例化.
12 XmlElement theBook = null, theElem = null, root = null;
13 XmlDocument xmldoc = new XmlDocument();
14 try
15 {
16 xmldoc.Load("Books.xml");
17 root = xmldoc.DocumentElement; // DocumentElement 获取xml文档对象的根XmlElement.
18
19 //--- 新建一本书开始 ----
20 theBook = xmldoc.CreateElement("book");
21 theElem = xmldoc.CreateElement("name");
22 theElem.InnerText = "新书";
23 theBook.AppendChild(theElem); //添加指定的节点的子节点列表的末尾.
24
25 theElem = xmldoc.CreateElement("price");

26 theElem.InnerText = "20"; // innerText: 所有子节点值的串联字符串.
27 theBook.AppendChild(theElem);
28
29 theElem = xmldoc.CreateElement("memo");
30 theElem.InnerText = "新书更好看。";
31 theBook.AppendChild(theElem);
32 root.AppendChild(theBook);
33 Console.Out.WriteLine("--- 新建一本书开始 ----");
34 Console.Out.WriteLine(root.OuterXml); //节点自身及其所以子节点的xml字符串.
35 //--- 新建一本书完成 ----
36
37 //--- 下面对《哈里波特》做一些修改。 ----
38 //--- 查询找《哈里波特》----
39 theBook = (XmlElement)root.SelectSingleNode("/books/book[name=''哈里波特'']"); //selectSingleNode 根据XPath表达式,获得符合条件的第一个节点.
40 Console.Out.WriteLine("--- 查找《哈里波特》 ----");
41 Console.Out.WriteLine(theBook.OuterXml);
42 //--- 此时修改这本书的价格 -----
43 theBook.GetElementsByTagName("price").Item(0).InnerText = "15";//getElementsByTagName返回的是NodeList,所以要跟上item(0)
44 Console.Out.WriteLine("--- 此时修改这本书的价格 ----");
45 Console.Out.WriteLine(theBook.OuterXml);
46 //--- 另外还想加一个属性id,值为B01 ----
47 theBook.SetAttribute("id", "B01");
48 Console.Out.WriteLine("--- 另外还想加一个属性id,值为B01 ----");
49 Console.Out.WriteLine(theBook.OuterXml);
50 //--- 对《哈里波特》修改完成。 ----
51
52 //--- 要用id属性删除----
53 theBook = (XmlElement)root.SelectSingleNode("/books/book[@id=''B02'']");
54 Console.Out.WriteLine("--- 要用id属性删除《三国演义》这本书 ----");
55 Console.Out.WriteLine(theBook.OuterXml);
56 theBook.ParentNode.RemoveChild(theBook);
57 Console.Out.WriteLine("--- 删除后的XML ----");
58 Console.Out.WriteLine(xmldoc.OuterXml);
59
60 //--- 再将所有价格低于10的书删除 ----
61 XmlNodeList someBooks = root.SelectNodes("/books/book[price<10]");
62 Console.Out.WriteLine("--- 再将所有价格低于10的书删除 ---");
63 Console.Out.WriteLine("--- 符合条件的书有 " someBooks.Count "本。 ---");
64
65 for (int i = 0; i < someBooks.Count; i ++ )
66 {
67 someBooks.Item(i).ParentNode.RemoveChild(someBooks.Item(i));
68 }
69 Console.Out.WriteLine("--- 删除后的XML ----");
70 Console.Out.WriteLine(xmldoc.OuterXml);
71
72 xmldoc.Save("books.xml");//保存到books.xml
73
74 Console.In.Read();
75 }
76 catch (Exception e)
77 {
78 Console.Out.WriteLine(e.Message);
79 }
80 }
81 }
82}

http://ivyliner.blog.163.com/blog/static/1181870342010525105051407/
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值