C# XML文件操作

运行环境:Window7 64bit,.NetFramework4.61,C# 6.0; 编者:乌龙哈里 2017-02-09


参考


章节

  • 创建
  • 读取
  • 修改
  • 添加
  • 删除
  • 带属性的xml

正文

一、创建

1、using System.Xml.Linq
2、XElement 类
3、示例:

string path = @"d:\test\test.xml";
XElement xe = new XElement("students",
    new XElement("student",
        new XElement("code","0001"),
        new XElement("name","Tony"),
        new XElement("score",100),
        new XElement("nclass",1),
        new XElement("ngrade",1)
     ),
     new XElement("student",
        new XElement("code", "0002"),
        new XElement("name", "Mike"),
        new XElement("score", 88),
        new XElement("nclass", 1),
        new XElement("ngrade", 1)
     ),
    new XElement("student",
        new XElement("code", "0003"),
        new XElement("name", "John"),
        new XElement("score", 90),
        new XElement("nclass", 2),
        new XElement("ngrade", 2)
     ),
    new XElement("student",
        new XElement("code", "0004"),
        new XElement("name", "Joe"),
        new XElement("score", 100),
        new XElement("nclass", 3),
        new XElement("ngrade", 3)
     )
);
xe.Save(path);

/*
<?xml version="1.0" encoding="utf-8"?>
<students>
  <student>
    <code>0001</code>
    <name>Tony</name>
    <score>100</score>
    <nclass>1</nclass>
    <ngrade>1</ngrade>
  </student>
  <student>
    <code>0002</code>
    <name>Mike</name>
    <score>88</score>
    <nclass>1</nclass>
    <ngrade>1</ngrade>
  </student>
  <student>
    <code>0003</code>
    <name>John</name>
    <score>90</score>
    <nclass>2</nclass>
    <ngrade>2</ngrade>
  </student>
  <student>
    <code>0004</code>
    <name>Joe</name>
    <score>100</score>
    <nclass>3</nclass>
    <ngrade>3</ngrade>
  </student>
</students>
*/

xml文件中第一句 <?xml version="1.0" encoding="utf-8"?> 是缺省加入的,如要更改需用到 XDocument 和 XDeclaration

string path = @"d:\test\test.xml";
XDocument doc = new XDocument(new XDeclaration("2.0", "utf-16", "yes"));
doc.Add(new XElement("root"));
doc.Save(path);
/*
<?xml version="1.0" encoding="utf-16" standalone="yes"?>
<root />
*/

出来的结果不知道为何version改不了。

二、读取

按上例,我们先弄一个数据结构:

class Student
 {
     public string code;
     public string name;
     public int score;
     public int nclass;
     public int ngrade;
 }

直接读取,xml 里面读取出来的全部都是 string 类型,注意转换成所需数据类型:

string path = @"d:\test\test.xml";
XElement xe = XElement.Load(path);
List<Student> list = new List<Student>();
foreach (var s in xe.Elements("student"))
{
    list.Add(new Student
    {
        code=s.Element("code").Value,
        name=s.Element("name").Value,
        score=int.Parse(s.Element("score").Value),
        nclass=int.Parse(s.Element("nclass").Value),
        ngrade=int.Parse(s.Element("ngrade").Value)
    });
 }

三、修改

1、根据值来直接修改。用lambda表达式很容易就能做到。

string path = @"d:\test\test.xml";
XElement xe = XElement.Load(path);
foreach(var a in xe.Elements("student"))
{
    Console.WriteLine(a.Element("name").Value);
}
Console.WriteLine();
//把name叫Tony的修改成Tom
xe.Elements("student").Where(x => x.Element("name").Value == "Tony").First().Element("name").SetValue("Tom");
foreach (var a in xe.Elements("student"))
{
    Console.WriteLine(a.Element("name").Value);
}

/*
Tony
Mike
John
Joe
Tom
Mike
John
Joe
*/

2、根据位置来修改。比如将第二项的 name 为 Mike 的 name 改成 Micheal :

//修改第二项数据,索引从0开始,所以是 index 为 1
xe.Elements("student").ElementAt(1).Element("name").SetValue("Micheal");

/*
Tony
Mike
John
Joe
Tony
Micheal
John
Joe
*/

四、添加

1、添加整项数据:

string path = @"d:\test\test.xml";
XElement xe = XElement.Load(path);
XElement t = new XElement("student",
         new XElement("code", "0005"),
         new XElement("name", "Petter"),
         new XElement("score", 98),
         new XElement("nclass", 1),
         new XElement("ngrade", 1)
);
//添加
xe.Add(t);
foreach (var a in xe.Elements("student"))
{
    Console.WriteLine(a.Element("name").Value);
}

/*
Tony
Mike
John
Joe
Petter
*/

2、给数据添加新项。比如我想给数据2添加个 sex 项,如下:

string path = @"d:\test\test.xml";
XElement xe = XElement.Load(path);
var x = xe.Elements("student").ElementAt(2);
foreach(var a in x.Descendants()){Console.WriteLine(a);}
Console.WriteLine();
//为数据添加新项
x.Add(new XElement("sex","male"));
foreach (var a in x.Descendants()){Console.WriteLine(a);}

/*
<code>0003</code>
<name>John</name>
<score>90</score>
<nclass>2</nclass>
<ngrade>2</ngrade>
<code>0003</code>
<name>John</name>
<score>90</score>
<nclass>2</nclass>
<ngrade>2</ngrade>
<sex>male</sex>
*/

3、如果我想把数据3
<code>0003</code>
<name>John</name>
<score>90</score>
<nclass>2</nclass>
<ngrade>2</ngrade>
中的 <score>90</score> 换成
<score>
<chinese>88</chinese>
<math>99</math>
</score>
用 ReplaceWith(),当然啦,也可以用先删除再添加:

XElement t = new XElement("score",
    new XElement("chinese",88),
    new XElement("math",99));
//替换
xe.Elements("student").ElementAt(2).Element("score").ReplaceWith(t);

五、删除

下面演示各种删除法,说白了就是如何操作 lambda 查询语句而已。

string path = @"d:\test\test.xml";
XElement xe = XElement.Load(path);
Console.WriteLine("===初始===");
foreach (var a in xe.Elements()) { Console.WriteLine(a.ToString()); }
//删除 name 为 John 的整个数据项
xe.Elements("student").Where(b=>b.Element("name").Value=="John").First().Remove();
Console.WriteLine("===删除John后===");
foreach (var a in xe.Elements()) { Console.WriteLine(a.ToString()); }
//删除 index 为 1 的数据
xe.Elements("student").ElementAt(1).Remove();
Console.WriteLine("===删除index 1 后===");
foreach (var a in xe.Elements()) { Console.WriteLine(a.ToString()); }
//删除 name 为 Tony 的 score 项
xe.Elements("student").Where(b => b.Element("name").Value == "Tony").First().Element("score").Remove();
Console.WriteLine("===删除 Tony 的 score 项===");
foreach (var a in xe.Elements()) { Console.WriteLine(a.ToString()); }

六、带属性的xml

比如这种:

/*
<book Type="必修课" ISBN="7-111-19149-2">
  <title>数据结构</title>
  <author>严蔚敏</author>
  <price>30.00</price>
</book>
*/

book 标记中的属性用 XAttribute 来定义:

XElement xe = new XElement ( "bookstore",
    new XElement("book",
        new XAttribute("Type","必修课"),
        new XAttribute("ISBN","7-111-19149-2"),
        new XElement("title","数据结构"),
        new XElement("author","严蔚敏"),
        new XElement("price","30.00"))
);

下来的操作就和不带 attribute 的差不多,比如把 必修课 属性改成 选修课:

xe.Elements().ElementAt(0).Attribute("Type").SetValue("选修课");

正文完。

题外话:这篇文章是我用自己定义的简单标记来书写的,包括程序的关键词染色,看来效果还成。

C# XML文件操作的更多相关文章

  1. 我来讲讲在c#中怎么进行xml文件操作吧,主要是讲解增删改查!

    我把我写的四种方法代码贴上来吧,照着写没啥问题. 注: <bookstore> <book> <Id>1</Id> <tate>2010-1 ...

  2. XML文件操作类--创建XML文件

    这个类是在微软XML操作类库上进行的封装,只是为了更加简单使用,包括XML类创建节点的示例. using System; using System.Collections; using System. ...

  3. PHP对XML文件操作之属性与方法讲解

    DOMDocument相关的内容. 属性: Attributes 存储节点的属性列表(只读) childNodes 存储节点的子节点列表(只读) dataType 返回此节点的数据类型 Definit ...

  4. 7.数据本地化CCString,CCArray,CCDictionary,tinyxml2,写入UserDefault.xml文件,操作xml,解析xml

     数据本地化 A CCUserDefault 系统会在默认路径cocos2d-x-2.2.3\projects\Hello\proj.win32\Debug.win32下生成一个名为UserDef ...

  5. SpringBatch Sample (三)(XML文件操作)

    前篇关于Spring Batch的文章,讲述了Spring Batch 对CSV文件的读写操作. 本文将通过一个完整的实例,与大家一起讨论运用Spring Batch对XML文件的读写操作.实例流程是 ...

  6. XML文件操作之dom4j

    能够操作xml的api还是挺多的,DOM也是可以的,不过在此记录下dom4j的使用,感觉确实挺方便的 所需jar包官网地址:http://www.dom4j.org/dom4j-1.6.1/ dom4 ...

  7. C#XML文件操作随笔

    以为公司一直没有电源屏厂家协议解析为DevVars相关的软件,手写费时费力还容易出错,用了2天时间做了一个.txt协议文件筛选加并解析成xml文件的工具,总结一下用到的几个知识点 1.LINQ 是一个 ...

  8. Xml文件操作的其中一个使用方法:

    XmlNodeList students = doc.DocumentElement.ChildNodes;//Student节点集合 foreach (XmlNode stu in students ...

  9. XML文件操作(C#)

    XML应用于Web开发的许多方面,常用于简化数据的存储和共享,它的设计宗旨是传输数据,而非显示数据.下面简单介绍一下C#是如何对XML文件进行读取的. 1.首先,建立XML对象并关联XML文件 str ...

随机推荐

  1. hdu1845

    题解: 只要输出n/2即可 代码: #include<cstdio> #include<cmath> #include<cstring> #include<a ...

  2. 远程登录MySQL

    mysql 远程连接数据库的二种方法   一.连接远程数据库: 1.显示密码 如:MySQL 连接远程数据库(192.168.5.116),端口“3306”,用户名为“root”,密码“123456” ...

  3. wc.exe(c语言实现)

    Github项目地址:https://github.com/zhongciting2009/wc WC 项目要求 wc.exe 是一个常见的工具,它能统计文本文件的字符数.单词数和行数.这个项目要求写 ...

  4. 遮罩效果 css3

    CSS3提供了遮罩效果,这是以前CSS2中比较难实现的一个新特性,配合SVG或者canvas同样也可以实现遮罩效果,他的效果就如下图所示: 简单的说就是在一个层上面加一个过滤层,过滤层透明度越低,底层 ...

  5. ORM版,学生信息管理单表查询..

    mysql 建学生表及课程表 添加内容 view.py from django.shortcuts import render,HttpResponse,redirect from . import ...

  6. Python解析excel文件并存入sqlite数据库

    最近由于工作上的需求 需要使用Python解析excel文件并存入sqlite 就此做个总结 功能:1.数据库设计 建立数据库2.Python解析excel文件3.Python读取文件名并解析4.将解 ...

  7. 如何将u盘、移动硬盘转化为活动分区--绝招

    https://jingyan.baidu.com/article/e75057f2a6a18aebc91a893e.html

  8. egg 使用手记(一)

    1. 文件加载规则 引用官方的说法: 框架在加载文件时会进行转换,因为文件命名风格和 API 风格存在差异.我们推荐文件使用下划线,而 API 使用驼峰.比如 app/service/user_inf ...

  9. MySQL中创建用户与授权

    参考地址:http://blog.csdn.net/gebitan505/article/details/51726649 一.创建用户(使用root用户登录进入mysql命令行) create us ...

  10. css学习笔记之图像

    图像与文本的对齐方式: vertical-align:text-top;表示的意思是图像的顶部和同一行的文本对齐,但文本不会超出图片的上边线. vertical-align:middle;表示的意思是 ...