c#操作XML

操作XML文件示例
我用的是一种很笨的方法,但可以帮助初学者了解访问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);//显示子节点点文本
    }
   }
 
C# 读取 XML 文件有多种方法,以下为你详细介绍: ### 使用 `XmlDocument` 操作 `XmlDocument` 是一个用于处理 XML 数据的类,它可以将 XML 文件加载到内存中,并提供了一系列方法和属性来操作 XML 节点。示例代码如下: ```csharp using System; using System.Collections.Generic; using System.Xml; class Program { static void Main() { // 获取所有一级目录 List<string> devices = new List<string>(); XmlDocument doc = new XmlDocument(); doc.Load(AppDomain.CurrentDomain.BaseDirectory + @"\TEMP\Configs.xml"); XmlNode xnl1 = doc.DocumentElement; foreach (XmlNode xn1 in xnl1.ChildNodes) { XmlElement xe1 = (XmlElement)xn1; devices.Add(xe1.GetAttribute("name").ToString()); } // 获取某个一级目录下的子目录 List<string> types = new List<string>(); doc = new XmlDocument(); doc.Load(AppDomain.CurrentDomain.BaseDirectory + @"\TEMP\Configs.xml"); xnl1 = doc.DocumentElement; foreach (XmlNode xn1 in xnl1) { XmlElement xe1 = (XmlElement)xn1; if (xe1.GetAttribute("name").ToString() == "aaa") { XmlNodeList xnl2 = xe1.ChildNodes; foreach (XmlNode xn2 in xnl2) { XmlElement xe2 = (XmlElement)xn2; types.Add(xe2.GetAttribute("name").ToString()); } break; } } } } ``` ### 使用 `XmlTextReader`/`XmlTextWriter` 操作 `XmlTextReader` 用于读取 XML 文件,`XmlTextWriter` 用于写入 XML 文件。这种方式是基于流的方式,逐行读取 XML 文件,适合处理大型 XML 文件。示例代码如下: ```csharp using System; using System.Xml; class Program { static void Main() { using (XmlTextReader reader = new XmlTextReader("path/to/your/xml/file.xml")) { while (reader.Read()) { if (reader.NodeType == XmlNodeType.Element) { Console.WriteLine("Element: " + reader.Name); } } } } } ``` ### 使用 `Linq to Xml` 操作 `Linq to Xml` 是一种基于 LINQ 的 XML 处理方式,它提供了一种更简洁、更灵活的方式来处理 XML 数据。示例代码如下: ```csharp using System; using System.Linq; using System.Xml.Linq; class Program { static void Main() { XDocument doc = XDocument.Load("path/to/your/xml/file.xml"); var elements = from el in doc.Descendants("elementName") select el; foreach (var element in elements) { Console.WriteLine(element.Value); } } } ``` ### 使用 `DataSet` 操作 `DataSet` 可以将 XML 文件加载到内存中,并将其转换为表格形式,方便进行数据操作。这种方式最简单,而且取数据也很方便,但是对于比较复杂的 XML操作起来也很麻烦,每一个带属性的节点都会生成一个 table。示例代码如下: ```csharp using System; using System.Data; class Program { static void Main() { // xml 文件路径 string xmlPath = Application.StartupPath + "\\Student.xml"; // 不带属性 string xmlPaths = Application.StartupPath + "\\Students.xml"; // 带属性 // dataset 读取简单 xml 文件 DataSet ds = new DataSet(); ds.ReadXml(xmlPath); // 读取第一条数据的 name 节点 string name = ds.Tables[0].Rows[0]["name"].ToString(); Console.WriteLine(name); // dataset 读取带属性的 xml 文件 ds = new DataSet(); ds.ReadXml(xmlPaths); // 读取的节点名称 string nodeName = "name"; name = ds.Tables[nodeName].Rows[0][nodeName + "_Text"].ToString(); // 读取节点的 id 属性 string id = ds.Tables[nodeName].Rows[0]["id"].ToString(); Console.WriteLine("id:{0},name:{1}", id, name); } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值