C# 对XML操作入门实例

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

代码如下:

<?xmlversion="1.0"encoding="gb2312"?>
 <bookstore>
 <bookgenre="fantasy"ISBN="2-3631-4">
 <title>Oberon'sLegacy</title>
 <author>Corets,Eva</author>
 <price>5.95</price>
 </book>
 </bookstore>

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

代码如下:

XmlDocumentxmlDoc=newXmlDocument();
 xmlDoc.Load("bookstore.xml");
 XmlNoderoot=xmlDoc.SelectSingleNode("bookstore");//查找<bookstore>
 XmlElementxe1=xmlDoc.createElement_x("book");//创建一个<book>节点
 xe1.SetAttribute("genre","李赞红");//设置该节点genre属性
 xe1.SetAttribute("ISBN","2-3631-4");//设置该节点ISBN属性

XmlElementxesub1=xmlDoc.createElement_x("title");
 xesub1.InnerText="CS从入门到精通";//设置文本节点
 xe1.AppendChild(xesub1);//添加到<book>节点中
 XmlElementxesub2=xmlDoc.createElement_x("author");
 xesub2.InnerText="候捷";
 xe1.AppendChild(xesub2);
 XmlElementxesub3=xmlDoc.createElement_x("price");
 xesub3.InnerText="58.3";
 xe1.AppendChild(xesub3);

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

//================
 结果为:

代码如下:

<?xmlversion="1.0"encoding="gb2312"?>
 <bookstore>
 <bookgenre="fantasy"ISBN="2-3631-4">
 <title>Oberon'sLegacy</title>
 <author>Corets,Eva</author>
 <price>5.95</price>
 </book>
 <bookgenre="李赞红"ISBN="2-3631-4">
 <title>CS从入门到精通</title>
 <author>候捷</author>
 <price>58.3</price>
 </book>
 </bookstore>

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

代码如下:

XmlNodeListnodeList=xmlDoc.SelectSingleNode("bookstore").ChildNodes;//获取bookstore节点的所有子节点
 foreach(XmlNodexninnodeList)//遍历所有子节点
 {
 XmlElementxe=(XmlElement)xn;//将子节点类型转换为XmlElement类型
 if(xe.GetAttribute("genre")=="李赞红")//如果genre属性值为“李赞红”
 {
 xe.SetAttribute("genre","update李赞红");//则修改该属性为“update李赞红”

XmlNodeListnls=xe.ChildNodes;//继续获取xe子节点的所有子节点
 foreach(XmlNodexn1innls)//遍历
 {
 XmlElementxe2=(XmlElement)xn1;//转换类型
 if(xe2.Name=="author")//如果找到
 {
 xe2.InnerText="亚胜";//则修改
 break;//找到退出来就可以了
 }
 }
 break;
 }
 }

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

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

最后结果为:

代码如下:

<?xmlversion="1.0"encoding="gb2312"?>
 <bookstore>
 <bookgenre="fantasy"ISBN="2-3631-4">
 <title>Oberon'sLegacy</title>
 <author>Corets,Eva</author>
 <price>5.95</price>
 </book>
 <bookgenre="update李赞红"ISBN="2-3631-4">
 <title>CS从入门到精通</title>
 <author>亚胜</author>
 <price>58.3</price>
 </book>
 </bookstore>

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

代码如下:

XmlNodeListxnl=xmlDoc.SelectSingleNode("bookstore").ChildNodes;

foreach(XmlNodexninxnl)
 {
 XmlElementxe=(XmlElement)xn;

if(xe.GetAttribute("genre")=="fantasy")
 {
 xe.RemoveAttribute("genre");//删除genre属性
 }
 elseif(xe.GetAttribute("genre")=="update李赞红")
 {
 xe.RemoveAll();//删除该节点的全部内容
 }
 }
 xmlDoc.Save("bookstore.xml");

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

最后结果为:

代码如下:

<?xmlversion="1.0"encoding="gb2312"?>
 <bookstore>
 <bookISBN="2-3631-4">
 <title>Oberon'sLegacy</title>
 <author>Corets,Eva</author>
 <price>5.95</price>
 </book>
 <book>
 </book>
 </bookstore>

4、显示所有数据。

代码如下:

XmlNodexn=xmlDoc.SelectSingleNode("bookstore");

XmlNodeListxnl=xn.ChildNodes;

foreach(XmlNodexnfinxnl)
 {
 XmlElementxe=(XmlElement)xnf;
 Console.WriteLine(xe.GetAttribute("genre"));//显示属性值
 Console.WriteLine(xe.GetAttribute("ISBN"));

XmlNodeListxnf1=xe.ChildNodes;
 foreach(XmlNodexn2inxnf1)
 {
 Console.WriteLine(xn2.InnerText);//显示子节点点文本
 }
 }

(0)

相关推荐

  • C# XML操作 代码大全(读XML,写XML,更新,删除节点,与dataset结合等)第1/2页

    已知有一个XML文件(bookstore.xml)如下: Corets, Eva 5.95 1.插入节点 往节点中插入一个节点: 复制代码 代码如下: XmlDocument xmlDoc=new XmlDocument(); xmlDoc.Load("bookstore.xml"); XmlNode root=xmlDoc.SelectSingleNode("bookstore");//查找 XmlElement xe1=xmlDoc.CreateElement(

  • c#对xml的简单操作

    xml文件格式如下:  <?xml version="1.0" encoding="utf-8"?>  <userdata createuser="false">  <dataconnection>  <server>localhost</server>  <uid>sa</uid>  <pwd></pwd>  </dataconne

  • c#操作xml帮助类分享(xml增删改查)

    复制代码 代码如下: using System;using System.Collections;using System.Xml; namespace Jb51.Com.XmlDAL{public class XmlHelper{#region 公共变量XmlDocument xmldoc;XmlNode xmlnode;XmlElement xmlelem;#endregion #region 创建Xml文档/// <summary>/// 创建一个带有根节点的Xml文件/// </

  • C# 操作XML文档 使用XmlDocument类方法

    W3C制定了XML DOM标准.很多编程语言中多提供了支持W3C XML DOM标准的API.我在之前的文章中介绍过如何使用Javascript对XML文档进行加载与查询.在本文中,我来介绍一下.Net中的XmlDocument类.它支持并扩展了W3C XML DOM标准.它将整个XML文档都先装载进内存中,然后再对XML文档进行操作,所以如果XML文档内容过大,不建议使用XmlDocument类,因为会消耗过多内存.对于很大的XML文档,可以使用XmlReader类来读取.因为XmlReade

  • c#操作xml文件示例

    1. 新增XML文件 复制代码 代码如下: XMLToolV2 _xmlHelper = new XMLToolV2(@"C:\20140311blogs.xml");//xml保存路径或者读取路径 _xmlHelper.Create("Person", "utf-8");//跟节点名称:person;encode:utf-8 XmlElement _person = _xmlHelper.CreateElec("Name",

  • asp.net(C#) Xml操作(增删改查)练习

    web.config配置: 复制代码 代码如下: <appSettings> <add key="xmlFile" value="xml/class.xml"/> </appSettings> <appSettings> <add key="xmlFile" value="xml/class.xml"/> </appSettings> 前台: 复制代码 代

  • c#对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&l

  • 操作XML文档遇到的XMLNS问题及解决方法 (C# 和 PHP)

    而昨晚在使用 XPATH 的时候, 遇到一个问题, 改了一个晚上才搞定, 差点没吐血. 果然基础知识要掌握扎实啊!! 假设有以下一份 XML 文档: 我们要获取所有歌曲的标题, 一般是使用以下的 XPATH 表达式: 复制代码 代码如下: /playlist/trackList/track/title 但是匹配的结果会让你非常失望, 你会发现什么也得不到. 于是我在这个问题上卡了好几个小时, 最终万能的 Google 告诉了我答案. 在第二行 playlist 那个节点, 有一个 XMLNS 属

  • C#操作XML文件实例汇总

    针对XML文件的操作是C#程序设计中非常常见的功能.本文即以实例展示了C#操作XML文件的几个常见的示例.具体如下: 1.返回节点下标 public static XmlDocument getDoc(String path)//加载xml文档 { XmlDocument doc = new XmlDocument(); doc.Load(path); return doc; } /// <summary> /// 返回找到的节点下标 /// </summary> /// <

  • C# 对XML基本操作代码总结

    具体如下: XML文件:文件在MyDocument文件夹下 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?> <PersonF xmlns="" Name="(test)work hard work smart!"> <person Name="Person1"> <ID>1</ID> <Na

  • c# xml API操作的小例子

    复制代码 代码如下: LoginInfo loginInfo = new LoginInfo();xmlNode = _xml.SelectSingleNode(loginUrl);loginInfo.LoginUrl = xmlNode.InnerText;xmlNode = _xml.SelectSingleNode(loginUser);loginInfo.UserId = xmlNode.Attributes["tagId"].Value;loginInfo.UserValue

随机推荐