1、c#对XML文件的解析
1、XML文件
<?xml version="1.0" encoding="utf-8"?>
<PersonF xmlns="" Name="(test)work hard work smart!">
<person Name="Person1">
<ID>1</ID>
<Name>XiaoA</Name>
<Age>59</Age>
</person>
<person Name="Person2">
<ID>2</ID>
<Name>XiaoB</Name>
<Age>29</Age>
</person>
<person Name="Person3">
<ID>3</ID>
<Name>XiaoC</Name>
<Age>103</Age>
</person>
<person Name="Person4">
<ID>4</ID>
<Name>XiaoD</Name>
<Age>59</Age>
</person>
</PersonF>
2、程序代码
string path = @"E:\测试\XML读取\XML.xml";
XmlDocument xd = new XmlDocument();
try
{
xd.Load(path);
switch (count)
{
case :
//1、读取单个节点的数据
XmlNode xn1= xd.SelectSingleNode("PersonF");
richTextBox1.Text = xn1.InnerText.ToString();
count++;break;
case :
//2、读取多个节点的数据
XmlNodeList xn2 = xd.SelectNodes("PersonF/person");
foreach (XmlNode xn in xn2)
{
richTextBox1.Text += xn.InnerText;
}
count++;break;
case :
//3.1、读取具体节点的具体值 如:Name属性为Person2的Name的InnerText
XmlNodeList xn3 = xd.DocumentElement.GetElementsByTagName("person");
foreach (XmlNode xn in xn3)
{
if (xn.Attributes["Name"].InnerText == "Person2")
{
richTextBox1.Text += xn.InnerText;
}
}
count++; break;
case :
//3.2、读取ID为2所在的节点第二个子节点Name的InnerText
XmlNode xn4 = xd.SelectSingleNode("PersonF/person[ID=2]");
richTextBox1.Text = xn4.ChildNodes[].InnerText;
count++; break;
case :
//3.3、找到ID为2的节点的父节点Name属性
XmlNodeList xn5 = xd.SelectNodes("//person//ID");//读取ID为2的节点
foreach (XmlNode xn in xn5)
{
if (xn.InnerText == "")
{
richTextBox1.Text += xn.ParentNode.Attributes["Name"].InnerText;
}
}
count++;break;
case :
//4、修改节点属性
XmlNode xn6 = xd.SelectSingleNode("PersonF");
xn6.Attributes["Name"].InnerText = "helloworld";
xd.Save(path);
count++; break;
case :
//5、添加自定义节点
XmlTextReader xr = new XmlTextReader(path);
XmlElement root = xd.DocumentElement;//根节点(最外层节点) XmlElement newele = xd.CreateElement("person");//第二层节点
newele.SetAttribute("Name", "Person6"); XmlElement ele_id = xd.CreateElement("ID");//newele子节点
ele_id.InnerText = "";
XmlElement ele_name = xd.CreateElement("Name");//newele子节点
ele_name.InnerText = "XiaoE";
newele.AppendChild(ele_id);
newele.AppendChild(ele_name);
root.AppendChild(newele); xr.Close();
xd.Save(path); count=; break;
} }
catch
{
Exception ex;
}
源码下载:http://pan.baidu.com/s/1dDRzZ4P
3.XPath详解
1)"/bookstore/book/price"
XPath的开头是一个斜线(/)代表这是绝对路径,这可以选出所有路径符合这个模式的元素。这代表选出所有bookstore根节点下的book元素下的price元素。
2)"//title"
开头是两个斜线(//)表示文件中所有符合模式的元素都会被选出来,即使是处于树中不同的层级也会被选出来。这代表选出所有title元素。
3)"/bookstore/book/author/*"
使用星号(*)可以选择未知的元素。这代表选出bookstore根节点下的book节点下的anthor节点下的所有可能的节点。
得到的结果:25 25 female
4)"/bookstore/book/*/age"
上面的语法会选出所有bookstore根节点下的book节点的隔一个层次的age节点。
得到的结果为:25 25
5)"/*/*/age"
选取有两个层级的age元素,得到的结果为:100
要注意的是,想要存取不分层级的元素,XPath语法必须以两个斜线开头(//),想要存取未知元素才用星号(*),星号只能代表未知名称的元素,不能代表未知层级的元素。
6)"bookstore/book[1]/title"
使用中括号可以选择分支。这代表选择bookstore根节点下第一个book节点的title节点。
得到的结果为:C语言
7)"bookstore/book[last()]/title"
同样,这里表示选择最后一个节点,得到的结果是:数据结构
8)"bookstore/book/author[sex]"
这里表示选取所有带有sex元素并满足一定层次结构的author节点,得到的结果是:25female
9)"/bookstore/book[price=66.5]/title"
选取price元素值是66.5的book节点的title子节点,得到的结果是:数据结构
10)"/bookstore/book/title | /bookstore/book/price"
使用Or操作数(|)就可以选择一个以上的路径。这里表示选取符合一定层次结构的title元素与price元素
其结果是:C语言 50 数据库 100 数据结构 66.5
11)"//@name"
在XPath中,除了选择元素以外,也可以选择属性,属性都是以@开头。这里表示选取所有的name属性。
其结果是:XIAO Wang
12)"//author[@name]/age"
这里表示选取所有具有name属性的author节点的age节点。其结果是:25 25
13)"//*[@*]"
选取所有有属性的节点。其结果是:25 25female
14)"//author[@name='Wang']/sex"
选取所有属性name值为Wang的author节点的sex子节点。其结果是:female
小结:
1. 读写整个XML最方便的方法是使用序列化反序列化。
2. 如果您希望某个参数以Xml Property的形式出现,那么需要使用[XmlAttribute]修饰它。
3. 如果您希望某个参数以Xml Element的形式出现,那么需要使用[XmlElement]修饰它。
4. 如果您希望为某个List的项目指定ElementName,则需要[XmlArrayItem]
5. 以上3个Attribute都可以指定在XML中的映射别名。
6. 写XML的操作是通过XmlSerializer.Serialize()来实现的。
7. 读取XML文件是通过XmlSerializer.Deserialize来实现的。
8. List或Array项,请不要使用[XmlElement],否则它们将以内联的形式提升到当前类,除非你再定义一个容器类。
最新文章
- SQL Server 2014聚集列存储索引
- 【再探backbone 02】集合-Collection
- Linux 中如何卸载已安装的软件(转载)
- Laravel5.1-Eloquent ORM:起步
- hiho #1318 非法二进制数
- pytion学习1
- asp.net截取指定长度的字符串内容
- 堆表和%%lockres%%函数
- nodejs的模块系统(实例分析exprots和module.exprots)
- Nginx、LVS及HAProxy负载均衡软件的优缺点详解
- Java基础知识强化之IO流笔记23:计算机是如何识别把两个字节拼接为中文(附加)
- Android的消息处理机制(Looper,Handler,Message)(转)
- SQL Server 日志文件增长原因定位
- hdu 1671 Phone List(字典树)
- C#如何实现url短地址?C#短网址压缩算法与短网址原理入门
- php实现socket推送技术
- 关于 target=";_blank";漏洞的分析
- Interpreting NotifyCollectionChangedEventArgs zz
- python 中的 list dict 与 set 的关系
- linux系统操作笔记
热门文章
- 如何修改mysql用户名和密码
- Android Studio常见问题 -- uses-sdk:minSdkVersion 8 cannot be smaller than version 9 declared in library
- 【CSU1812】三角形和矩形 【半平面交】
- django";动态网页";,";动态url";,";调试方法";
- css学习笔记 1
- Clojure学习笔记(一)——介绍、安装和语法
- OpenBSD为何还在用CVS之感
- 忘记了MariaDB root密码的解决办法
- js中的cookie操作
- CASE表达式的使用