在C#.net中如何操作XML

简介: 在C#.net中如何操作XML 需要添加的命名空间: using System.Xml; 定义几个公共对象: XmlDocument xmldoc ; XmlNode xmlnode ; XmlElement xmlelem ; 1,创建到服务器同名目录下的xml文件: 方法一: xmld...
在C#.net中如何操作XML
 需要添加的命名空间:
  using System.Xml;
 
定义几个公共对象:
 XmlDocument xmldoc ;
 XmlNode xmlnode ;
 XmlElement xmlelem ;
 
1,创建到服务器同名目录下的xml文件:
 

方法一:
 xmldoc =  new XmlDocument ( ) ;
  // 加入XML的声明段落,<?xml version="1.0" encoding="gb2312"?>
 XmlDeclaration xmldecl;
  xmldecl = xmldoc.CreateXmlDeclaration( " 1.0 ", " gb2312 ", null);
  xmldoc.AppendChild ( xmldecl);
 
// 加入一个根元素
 xmlelem = xmldoc.CreateElement (  "" ,  " Employees " ,  "" ) ;
 xmldoc.AppendChild ( xmlelem ) ;
  // 加入另外一个元素
  for( int i= 1;i< 3;i++)
 {
 
XmlNode root=xmldoc.SelectSingleNode( " Employees "); // 查找<Employees> 
XmlElement xe1=xmldoc.CreateElement( " Node "); // 创建一个<Node>节点 
xe1.SetAttribute( " genre ", " 李赞红 "); // 设置该节点genre属性 
xe1.SetAttribute( " ISBN ", " 2-3631-4 "); // 设置该节点ISBN属性 

XmlElement xesub1=xmldoc.CreateElement( " title "); 
xesub1.InnerText= " CS从入门到精通 "; // 设置文本节点 
xe1.AppendChild(xesub1); // 添加到<Node>节点中 
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); // 添加到<Employees>节点中 
}
  // 保存创建好的XML文档
 xmldoc.Save ( Server.MapPath( " data.xml ") ) ; 

//////////////////////////////////////////////////////////////////////////////////// //
 结果:在同名目录下生成了名为data.xml的文件,内容如下,
 <?xml version= " 1.0 " encoding= " gb2312 "?>
 <Employees>
   <Node genre= " 李赞红 " ISBN= " 2-3631-4 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
   </Node>
   <Node genre= " 李赞红 " ISBN= " 2-3631-4 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
   </Node>
 </Employees>
 

方法二:
 XmlTextWriter xmlWriter;
     string strFilename = Server.MapPath( " data1.xml ") ;
 
   xmlWriter =  new XmlTextWriter(strFilename,Encoding.Default); // 创建一个xml文档
    xmlWriter.Formatting = Formatting.Indented;
    xmlWriter.WriteStartDocument();
    xmlWriter.WriteStartElement( " Employees ");
 
   xmlWriter.WriteStartElement( " Node ");
    xmlWriter.WriteAttributeString( " genre ", " 李赞红 ");
    xmlWriter.WriteAttributeString( " ISBN ", " 2-3631-4 ");
 
   xmlWriter.WriteStartElement( " title ");
    xmlWriter.WriteString( " CS从入门到精通 ");
    xmlWriter.WriteEndElement();
 
   xmlWriter.WriteStartElement( " author ");
    xmlWriter.WriteString( " 候捷 ");
    xmlWriter.WriteEndElement();
 
   xmlWriter.WriteStartElement( " price ");
    xmlWriter.WriteString( " 58.3 ");
    xmlWriter.WriteEndElement();
 
   xmlWriter.WriteEndElement();
 
   xmlWriter.Close();
  //////////////////////////////////////////////////////////////////////////////////// //
 结果:
 <?xml version= " 1.0 " encoding= " gb2312 "?>
 <Employees>
   <Node genre= " 李赞红 " ISBN= " 2-3631-4 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
   </Node>
 </Employees>
 
2,添加一个结点:
 
XmlDocument xmlDoc= new XmlDocument(); 
xmlDoc.Load(Server.MapPath( " data.xml ")); 
XmlNode root=xmlDoc.SelectSingleNode( " Employees "); // 查找<Employees> 
XmlElement xe1=xmlDoc.CreateElement( " Node "); // 创建一个<Node>节点 
xe1.SetAttribute( " genre ", " 张三 "); // 设置该节点genre属性 
xe1.SetAttribute( " ISBN ", " 1-1111-1 "); // 设置该节点ISBN属性 

XmlElement xesub1=xmlDoc.CreateElement( " title "); 
xesub1.InnerText= " C#入门帮助 "; // 设置文本节点 
xe1.AppendChild(xesub1); // 添加到<Node>节点中 
XmlElement xesub2=xmlDoc.CreateElement( " author "); 
xesub2.InnerText= " 高手 "
xe1.AppendChild(xesub2); 
XmlElement xesub3=xmlDoc.CreateElement( " price "); 
xesub3.InnerText= " 158.3 "
xe1.AppendChild(xesub3); 

root.AppendChild(xe1); // 添加到<Employees>节点中 
xmlDoc.Save ( Server.MapPath( " data.xml ") );
 
//////////////////////////////////////////////////////////////////////////////////// //
 结果:在xml原有的内容里添加了一个结点,内容如下,
 <?xml version= " 1.0 " encoding= " gb2312 "?>
 <Employees>
   <Node genre= " 李赞红 " ISBN= " 2-3631-4 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
   </Node>
   <Node genre= " 李赞红 " ISBN= " 2-3631-4 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
   </Node>
   <Node genre= " 张三 " ISBN= " 1-1111-1 ">
     <title>C#入门帮助</title>
     <author>高手</author>
     <price> 158.3</price>
   </Node>
 </Employees>
 
3,修改结点的值(属性和子结点):
 
XmlDocument xmlDoc= new XmlDocument(); 
xmlDoc.Load( Server.MapPath( " data.xml ") ); 

XmlNodeList nodeList=xmlDoc.SelectSingleNode( " Employees ").ChildNodes; // 获取Employees节点的所有子节点 

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= " 亚胜 "; // 则修改
 } 



xmlDoc.Save( Server.MapPath( " data.xml ") ); // 保存。
 
//////////////////////////////////////////////////////////////////////////////////// //
 结果:将原来的所有结点的信息都修改了,xml的内容如下,
 <?xml version= " 1.0 " encoding= " gb2312 "?>
 <Employees>
   <Node genre= " 李赞红 " ISBN= " 2-3631-4 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
   </Node>
   <Node genre= " 李赞红 " ISBN= " 2-3631-4 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
   </Node>
   <Node genre= " update张三 " ISBN= " 1-1111-1 ">
     <title>C#入门帮助</title>
     <author>亚胜</author>
     <price> 158.3</price>
   </Node>
 </Employees>
 
4,修改结点(添加结点的属性和添加结点的自结点):
 XmlDocument xmlDoc= new XmlDocument(); 
xmlDoc.Load( Server.MapPath( " data.xml ") ); 

XmlNodeList nodeList=xmlDoc.SelectSingleNode( " Employees ").ChildNodes; // 获取Employees节点的所有子节点 

foreach(XmlNode xn  in nodeList) 

XmlElement xe=(XmlElement)xn; 
xe.SetAttribute( " test ", " 111111 ");
 
XmlElement xesub=xmlDoc.CreateElement( " flag "); 
xesub.InnerText= " 1 "
xe.AppendChild(xesub); 

xmlDoc.Save( Server.MapPath( " data.xml ") );
 
//////////////////////////////////////////////////////////////////////////////////// //
 结果:每个结点的属性都添加了一个,子结点也添加了一个,内容如下,
 <?xml version= " 1.0 " encoding= " gb2312 "?>
 <Employees>
   <Node genre= " 李赞红 " ISBN= " 2-3631-4 " test= " 111111 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
     <flag> 1</flag>
   </Node>
   <Node genre= " 李赞红 " ISBN= " 2-3631-4 " test= " 111111 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
     <flag> 1</flag>
   </Node>
   <Node genre= " update张三 " ISBN= " 1-1111-1 " test= " 111111 ">
     <title>C#入门帮助</title>
     <author>亚胜</author>
     <price> 158.3</price>
     <flag> 1</flag>
   </Node>
 </Employees>
 
5,删除结点中的某一个属性:
 XmlDocument xmlDoc= new XmlDocument(); 
xmlDoc.Load( Server.MapPath( " data.xml ") ); 
XmlNodeList xnl=xmlDoc.SelectSingleNode( " Employees ").ChildNodes; 
foreach(XmlNode xn  in xnl) 

XmlElement xe=(XmlElement)xn; 
xe.RemoveAttribute( " genre "); // 删除genre属性 

XmlNodeList nls=xe.ChildNodes; // 继续获取xe子节点的所有子节点 
foreach(XmlNode xn1  in nls) // 遍历 

XmlElement xe2=(XmlElement)xn1; // 转换类型 
if(xe2.Name== " flag ") // 如果找到 

xe.RemoveChild(xe2); // 则删除
 } 


xmlDoc.Save( Server.MapPath( " data.xml ") ); 

//////////////////////////////////////////////////////////////////////////////////// //]
 结果:删除了结点的一个属性和结点的一个子结点,内容如下,
 <?xml version= " 1.0 " encoding= " gb2312 "?>
 <Employees>
   <Node ISBN= " 2-3631-4 " test= " 111111 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
   </Node>
   <Node ISBN= " 2-3631-4 " test= " 111111 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
   </Node>
   <Node ISBN= " 1-1111-1 " test= " 111111 ">
     <title>C#入门帮助</title>
     <author>亚胜</author>
     <price> 158.3</price>
   </Node>
 </Employees>
 
6,删除结点:
 XmlDocument xmlDoc= new XmlDocument(); 
xmlDoc.Load( Server.MapPath( " data.xml ") ); 
XmlNode root=xmlDoc.SelectSingleNode( " Employees ");
 XmlNodeList xnl=xmlDoc.SelectSingleNode( " Employees ").ChildNodes; 
for( int i= 0;i<xnl.Count;i++)
 {
 XmlElement xe=(XmlElement)xnl.Item(i); 
if(xe.GetAttribute( " genre ")== " 张三 "

root.RemoveChild(xe);
  if(i<xnl.Count)i=i- 1;
 } 
}
 xmlDoc.Save( Server.MapPath( " data.xml ") ); 

//////////////////////////////////////////////////////////////////////////////////// //]
 结果:删除了符合条件的所有结点,原来的内容:
 
<?xml version= " 1.0 " encoding= " gb2312 "?>
 <Employees>
   <Node genre= " 李赞红 " ISBN= " 2-3631-4 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
   </Node>
   <Node genre= " 李赞红 " ISBN= " 2-3631-4 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
   </Node>
   <Node genre= " 张三 " ISBN= " 1-1111-1 ">
     <title>C#入门帮助</title>
     <author>高手</author>
     <price> 158.3</price>
   </Node>
   <Node genre= " 张三 " ISBN= " 1-1111-1 ">
     <title>C#入门帮助</title>
     <author>高手</author>
     <price> 158.3</price>
   </Node>
 </Employees>
 
删除后的内容:
 <?xml version= " 1.0 " encoding= " gb2312 "?>
 <Employees>
   <Node genre= " 李赞红 " ISBN= " 2-3631-4 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
   </Node>
   <Node genre= " 李赞红 " ISBN= " 2-3631-4 ">
     <title>CS从入门到精通</title>
     <author>候捷</author>
     <price> 58.3</price>
   </Node>
 </Employees>
 
  7,按照文本文件读取xml
 
System.IO.StreamReader myFile = new 
 System.IO.StreamReader(Server.MapPath( " data.xml "),System.Text.Encoding.Default);
  // 注意System.Text.Encoding.Default
 
string myString = myFile.ReadToEnd(); // myString是读出的字符串
 myFile.Close();
目录
相关文章
|
11天前
|
数据可视化 网络协议 C#
C#/.NET/.NET Core优秀项目和框架2024年3月简报
公众号每月定期推广和分享的C#/.NET/.NET Core优秀项目和框架(每周至少会推荐两个优秀的项目和框架当然节假日除外),公众号推文中有项目和框架的介绍、功能特点、使用方式以及部分功能截图等(打不开或者打开GitHub很慢的同学可以优先查看公众号推文,文末一定会附带项目和框架源码地址)。注意:排名不分先后,都是十分优秀的开源项目和框架,每周定期更新分享(欢迎关注公众号:追逐时光者,第一时间获取每周精选分享资讯🔔)。
|
29天前
|
XML C# 数据格式
使用C#操作XML文件
使用C#操作XML文件
11 0
|
1月前
|
SQL 数据库 C#
C# .NET面试系列十一:数据库SQL查询(附建表语句)
#### 第1题 用一条 SQL 语句 查询出每门课都大于80 分的学生姓名 建表语句: ```sql create table tableA ( name varchar(10), kecheng varchar(10), fenshu int(11) ) DEFAULT CHARSET = 'utf8'; ``` 插入数据 ```sql insert into tableA values ('张三', '语文', 81); insert into tableA values ('张三', '数学', 75); insert into tableA values ('李四',
62 2
C# .NET面试系列十一:数据库SQL查询(附建表语句)
|
1月前
|
开发框架 算法 搜索推荐
C# .NET面试系列九:常见的算法
#### 1. 求质数 ```c# // 判断一个数是否为质数的方法 public static bool IsPrime(int number) { if (number < 2) { return false; } for (int i = 2; i <= Math.Sqrt(number); i++) { if (number % i == 0) { return false; } } return true; } class Progr
58 1
|
1月前
|
并行计算 安全 Java
C# .NET面试系列四:多线程
<h2>多线程 #### 1. 根据线程安全的相关知识,分析以下代码,当调用 test 方法时 i > 10 时是否会引起死锁? 并简要说明理由。 ```c# public void test(int i) { lock(this) { if (i > 10) { i--; test(i); } } } ``` 在给定的代码中,不会发生死锁。死锁通常是由于两个或多个线程互相等待对方释放锁而无法继续执行的情况。在这个代码中,只有一个线程持有锁,且没有其他线程参与,因此不
102 3
|
4天前
|
开发框架 前端开发 JavaScript
采用C#.Net +JavaScript 开发的云LIS系统源码 二级医院应用案例有演示
技术架构:Asp.NET CORE 3.1 MVC + SQLserver + Redis等 开发语言:C# 6.0、JavaScript 前端框架:JQuery、EasyUI、Bootstrap 后端框架:MVC、SQLSugar等 数 据 库:SQLserver 2012
|
1月前
|
XML 存储 JavaScript
深入学习 XML 解析器及 DOM 操作技术
所有主要的浏览器都内置了一个XML解析器,用于访问和操作XML XML 解析器 在访问XML文档之前,必须将其加载到XML DOM对象中 所有现代浏览器都有一个内置的XML解析器,可以将文本转换为XML DOM对象
72 0
|
1月前
|
开发框架 人工智能 .NET
C#/.NET/.NET Core拾遗补漏合集(持续更新)
C#/.NET/.NET Core拾遗补漏合集(持续更新)
|
1月前
|
SQL 存储 关系型数据库
C# .NET面试系列十:数据库概念知识
#### 1. 为什么要一定要设置主键? 设置主键是数据库设计中的一个重要概念,有几个主要原因: 1、唯一性 ```c# 主键必须保证表中的每一行都有唯一的标识。这样可以避免数据冗余和不一致性。如果没有主键或者主键不唯一,就可能出现数据混乱或错误。 ``` 2、查询性能 ```c# 数据库系统通常会使用主键来加速数据检索。主键通常会被索引,这样可以更快速地找到特定行的数据,提高查询效率。 ``` 3、关联性 ```c# 主键常常用于建立表与表之间的关系。在关系数据库中,一个表的主键通常与其他表中的外键建立关联,这种关系对于数据的一致性和完整性非常重要。 ``` 4、数据完
131 1
C# .NET面试系列十:数据库概念知识
|
1月前
|
XML 开发框架 .NET
C# .NET面试系列八:ADO.NET、XML、HTTP、AJAX、WebService
## 第二部分:ADO.NET、XML、HTTP、AJAX、WebService #### 1. .NET 和 C# 有什么区别? .NET(通用语言运行时): ```c# 定义:.NET 是一个软件开发框架,提供了一个通用的运行时环境,用于在不同的编程语言中执行代码。 作用:它为多语言支持提供了一个统一的平台,允许不同的语言共享类库和其他资源。.NET 包括 Common Language Runtime (CLR)、基础类库(BCL)和其他工具。 ``` C#(C Sharp): ```c# 定义: C# 是一种由微软设计的面向对象的编程语言,专门为.NET 平台开发而创建。 作
174 2