c#读取XML

XML文件是一种常用的文件格式,例如WinForm里面的app.config以及Web程序中的web.config文件,还有许多重要的场所都有它的身影。Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具。XML是一种简单的数据存储语言,使用一系列简单的标记描述数据,而这些标记可以用方便的方式建立,虽然XML占用的空间比二进制数据要占用更多的空间,但XML极其简单易于掌握和使用。微软也提供了一系列类库来倒帮助我们在应用程序中存储XML文件。

“在程序中访问进而操作XML文件一般有两种模型,分别是使用DOM(文档对象模型)和流模型,使用DOM的好处在于它允许编辑和更新XML文档,可以随机访问文档中的数据,可以使用XPath查询,但是,DOM的缺点在于它需要一次性的加载整个文档到内存中,对于大型的文档,这会造成资源问题。流模型很好的解决了这个问题,因为它对XML文件的访问采用的是流的概念,也就是说,任何时候在内存中只有当前节点,但它也有它的不足,它是只读的,仅向前的,不能在文档中执行向后导航操作。”具体参见在lVisual C#中使用XML指南之读取
XML

下面我将介绍三种常用的读取XML文件的方法。分别是

  1. 使用 XmlDocument
  2. 使用 XmlTextReader
  3. 使用 Linq to Xml

这里我先创建一个XML文件,名为Book.xml下面所有的方法都是基于这个XML文件的,文件内容如下:


<bookstore>
  
  <book Type="必修课11" ISBN="7-111-19149-2">
    <title>数据结构title>
    <author>严蔚敏author>
    <price>30price>
  book>
  <book Type="必修课" ISBN="7-111-19149-3">
    <title>路由型与交换型互联网基础title>
    <author>程庆梅author>
    <price>27.00price>
  book>
  <book Type="必修课" ISBN="7-111-19149-4">
    <title>计算机硬件技术基础title>
    <author>李继灿author>
    <price>25.00price>
  book>
  <book Type="必修课" ISBN="7-111-19149-5">
    <title>软件质量保证与管理title>
    <author>朱少民author>
    <price>39.00price>
  book>
  <book Type="222" ISBN="7-111-19149-6">
    <title>算法设计与分析title>
    <author>王红梅author>
    <price>23price>
  book>
  <book Type="选修课11" ISBN="7-111-19149-1">
    <title>计算机操作系统title>
    <author>7-111-19149-1author>
    <price>28price>
  book>
  <book Type="选修课" ISBN="112-225-25">
    <title>你必须知道的NETtitle>
    <author>YoungHaiqingauthor>
    <price>28price>
  book>
bookstore>

为了方便读取,我还定义一个书的实体类,名为BookModel,具体内容如下:

    /// 
    /// 图书信息类
    /// 
    public class BookModel
    {
        public BookModel()
        { }
        /// 
        /// 所对应的课程类型
        /// 
        private string bookType;

        public string BookType
        {
            get { return bookType; }
            set { bookType = value; }
        }

        /// 
        /// 书所对应的ISBN号
        /// 
        private string bookISBN;

        public string BookISBN
        {
            get { return bookISBN; }
            set { bookISBN = value; }
        }

        /// 
        /// 书名
        /// 
        private string bookName;

        public string BookName
        {
            get { return bookName; }
            set { bookName = value; }
        }

        /// 
        /// 作者
        /// 
        private string bookAuthor;

        public string BookAuthor
        {
            get { return bookAuthor; }
            set { bookAuthor = value; }
        }

        /// 
        /// 价格
        /// 
        private double bookPrice;

        public double BookPrice
        {
            get { return bookPrice; }
            set { bookPrice = value; }
        }
    }

1.使用XmlDocument.

 使用XmlDocument是一种基于文档结构模型的方式来读取XML文件.在XML文件中,我们可以把XML看作是由文档声明(Declare),元素(Element),属性(Attribute),文本(Text)等构成的一个树.最开始的一个结点叫作根结点,每个结点都可以有自己的子结点.得到一个结点后,可以通过一系列属性或方法得到这个结点的值或其它的一些属性.例如:

继承层次结构

System.Object
  System.Xml.XmlNode
    System.Xml.XmlDocument
      System.Configuration.ConfigXmlDocument
      System.Xml.XmlDataDocument

XmlDocument构造函数

名称 说明
XmlDocument() 初始化 XmlDocument 类的新实例。
XmlDocument(XmlImplementation) 使用指定的 XmlDocument 初始化 XmlImplementation 类的新实例。
XmlDocument(XmlNameTable) 使用指定的 XmlDocument 初始化 XmlNameTable 类的新实例。

属性

名称 说明
Attributes 获取 XmlAttributeCollection 包含此节点的属性。(继承自 XmlNode。)
ChildNodes 获取节点的所有子节点。(继承自 XmlNode。)
DocumentElement 获取文档的根 XmlElement。
InnerText 在所有情况下引发 InvalidOperationException。(覆盖 XmlNode.InnerText。)
Item[String] 获取具有指定的第一个子元素 Name。(继承自 XmlNode。)
Name 获取节点的限定名称。(覆盖 XmlNode.Name。)
Value 获取或设置节点的值。(继承自 XmlNode。)
…… …..

方法

名称 说明
AppendChild(XmlNode) 将指定的节点添加到该节点的子节点列表的末尾。(继承自 XmlNode。)
CreateAttribute(String) 创建具有指定 Name 的 XmlAttribute。
DocumentElement 获取文档的根 XmlElement。
CreateElement(String) 创建具有指定名称的元素。
GetEnumerator() 获取循环访问当前节点中子节点的枚举。(继承自 XmlNode。)
GetType() 获取当前实例的 Type。(继承自 Object。)
DocumentElement 获取文档的根 XmlElement。
Load(Stream) 从指定的流加载 XML 文档。
Load(TextReader) 从指定的 TextReader 加载 XML 文档。
Load(XmlReader) 从指定的 XmlReader 加载 XML 文档。
LoadXml(String) 从指定的字符串加载 XML 文档。
Save(XmlWriter) 将 XML 文档保存到指定的 XmlWriter。

具体请查看MSDN开发者文档

1.1 读取所有的数据.

使用的时候,首先声明一个XmlDocument对象,然后调用Load方法,从指定的路径加载XML文件.

  XmlDocument doc = new XmlDocument();
  doc.Load(@"D:\Book.xml");

然后可以通过调用SelectSingleNode得到指定的结点,通过GetAttribute得到具体的属性值.参看下面的代码

 XmlNode xn = doc.SelectSingleNode("bookstore");
            XmlNodeList xnl = xn.ChildNodes;
            List bookModeList = new List();
            foreach (XmlNode xns in xnl)
            {
                try
                {
                    BookModel bookModel = new BookModel();
                    // 将节点转换为元素,便于得到节点的属性值
                    XmlElement xe = (XmlElement)xns;
                    // 得到Type和ISBN两个属性的属性值
                    bookModel.BookISBN = xe.GetAttribute("ISBN").ToString();
                    bookModel.BookType = xe.GetAttribute("Type").ToString();
                    // 得到Book节点的所有子节点
                    XmlNodeList xnl0 = xe.ChildNodes;
                    bookModel.BookName = xnl0.Item(0).InnerText;
                    bookModel.BookAuthor = xnl0.Item(1).InnerText;
                    bookModel.BookPrice = Convert.ToDouble(xnl0.Item(2).InnerText);
                    bookModeList.Add(bookModel);
                }
                catch (Exception)
                {

                    continue;
                }
            }
            this.dgvBookInfo.DataSource = bookModeList;

在正常情况下,上面的代码好像没有什么问题,但是对于读取上面的XML文件,则会出错,原因就是因为我上面的XML文件里面有注释,大家可以参看Book.xml文件中的第三行,我随便加的一句注释.注释也是一种结点类型,在没有特别说明的情况下,会默认它也是一个结点(Node).所以在把结点转换成元素的时候就会报错.”无法将类型为“System.Xml.XmlComment”的对象强制转换为类型“System.Xml.XmlElement”。”
c#读取XML_第1张图片
幸亏它里面自带了解决办法,那就是在读取的时候,告诉编译器让它忽略掉里面的注释信息.修改如下:

 XmlDocument xmlDoc = new XmlDocument();
  XmlReaderSettings settings = new XmlReaderSettings();
   settings.IgnoreComments = true;//忽略文档里面的注释
   XmlReader reader = XmlReader.Create(@"..\..\Book.xml", settings);
   xmlDoc.Load(reader);

最后读取完毕后,记得要关掉reader.

reader.close();//此时将文件关闭,不然对其操作会提示,一个文件正在使用。

c#读取XML_第2张图片

1.2 增加一本书的信息.

向文件中添加新的数据的时候,首先也是通过XmlDocument加载整个文档,然后通过调用SelectSingleNode方法获得根结点,通过CreateElement方法创建元素,用CreateAttribute创建属性,用AppendChild把当前结点挂接在其它结点上,用SetAttributeNode设置结点的属性.具体代码如下:
加载文件并选出要结点:`

  ///加载文件并选出要结点:
            XmlDocument doc = new XmlDocument();
            doc.Load(@"D:\Book.xml");
            XmlNode xn = doc.SelectSingleNode("bookstore");

创建一个结点,并设置结点的属性:

 //创建一个结点,并设置结点的属性:
            XmlElement xelKey = doc.CreateElement("book");
            XmlAttribute xelType = doc.CreateAttribute("Type");
            xelType.InnerText = "选修课";

            XmlAttribute xelType1 = doc.CreateAttribute("ISBN");
            xelType1.InnerText = "112-225-25";

            xelKey.SetAttributeNode(xelType);
            xelKey.SetAttributeNode(xelType1);

创建子结点:

  //创建子结点:
            XmlElement title = doc.CreateElement("title");
            title.InnerText = "你必须知道的NET";
            XmlElement author = doc.CreateElement("author");
            author.InnerText = "YoungHaiqing";
            XmlElement price = doc.CreateElement("price");
            price.InnerText = "28";
            xelKey.AppendChild(title);
            xelKey.AppendChild(author);
            xelKey.AppendChild(price);

最后把book结点挂接在要结点上,并保存整个文件:

//最后把book结点挂接在要结点上,并保存整个文件:
            xn.AppendChild(xelKey);
            doc.Save(@"D:\Book.xml");

直接把根结点选择出来了,后面不用SelectSingleNode方法选择根结点,直接创建结点即可,代码同上.

1.3 删除某一个数据

想要删除某一个结点,直接找到其父结点,然后调用RemoveChild方法即可,现在关键的问题是如何找到这个结点,上面的SelectSingleNode可以传入一个Xpath表,我们通过书的ISBN号来找到这本书所在的结点.如下:

  XmlDocument doc = new XmlDocument();
            doc.Load(@"D:\Book.xml");
            XmlElement xe = doc.DocumentElement;
            string strPath = string.Format("/bookstore/book[@ISBN=\"{0}\"]", this.dgvBookInfo.CurrentRow.Cells[1].Value.ToString());
            XmlElement selectXe = (XmlElement)xe.SelectSingleNode(strPath);
            selectXe.ParentNode.RemoveChild(selectXe);
            doc.Save(@"D:\Book.xml");

*/bookstore/book[@ISBN=\”{0}*“]”是一个Xpath表达式,找到ISBN号为所选那一行ISBN号的那本书,有关Xpath的知识请参考:XPath 语法

1.4 修改某要条数据

修改某 条数据的话,首先也是用Xpath表达式找到所需要修改的那一个结点,然后如果是元素的话,就直接对这个元素赋值,如果是属性的话,就用SetAttribute方法设置即可.如下:

 XmlDocument doc = new XmlDocument();
            doc.Load(@"D:\Book.xml");
            XmlElement xe = doc.DocumentElement;
            string strPath = string.Format("/bookstore/book[@ISBN=\"{0}\"]", this.dgvBookInfo.CurrentRow.Cells[1].Value.ToString());

            XmlElement selectXe = (XmlElement)xe.SelectSingleNode(strPath);
            selectXe.SetAttribute("Type", dgvBookInfo.CurrentRow.Cells[0].Value.ToString());
            selectXe.GetElementsByTagName("title").Item(0).InnerText  = dgvBookInfo.CurrentRow.Cells[2].Value.ToString();
            selectXe.GetElementsByTagName("author").Item(0).InnerText = dgvBookInfo.CurrentRow.Cells[3].Value.ToString();
            selectXe.GetElementsByTagName("price").Item(0).InnerText  = dgvBookInfo.CurrentRow.Cells[4].Value.ToString();
            doc.Save(@"D:\Book.xml");

2.使用XmlTextReader和XmlTextWriter

XmlTextReader和XmlTextWriter是以流的形式来读写XML文件.

2.1XmlTextReader

使用XmlTextReader读取数据的时候,首先创建一个流,然后用read()方法来不断的向下读,根据读取的结点的类型来进行相应的操作.如下:

XmlTextReader reader = new XmlTextReader(@"D:\Book.xml");
           List modelList = new List();
           BookModel model = new BookModel();
           while (reader.Read())
           {

               if (reader.NodeType == XmlNodeType.Element)
               {
                   if (reader.Name == "book")
                   {
                       model.BookType = reader.GetAttribute(0);
                       model.BookISBN = reader.GetAttribute(1);
                   }
                   if (reader.Name == "title")
                   {
                       model.BookName=reader.ReadElementString().Trim();
                   }
                   if (reader.Name == "author")
                   {
                       model.BookAuthor = reader.ReadElementString().Trim();
                   }
                   if (reader.Name == "price")
                   {
                       model.BookPrice = Convert.ToDouble(reader.ReadElementString().Trim());
                   }
               }

               if (reader.NodeType == XmlNodeType.EndElement)
               {
                   modelList.Add(model);
                   model = new BookModel();
               }


           }
           modelList.RemoveAt(modelList.Count-1);
           this.dgvBookInfo.DataSource = modelList;

关键是读取属性的时候,你要先知道哪一个结点具有几个属性,然后通过GetAttribute方法来读取.读取属性还可以用另外一种方法,就是用MoveToAttribute方法.可参见下面的代码:


if (reader.Name == "book")
    {
        for (int i = 0; i < reader.AttributeCount; i++)
        {
            reader.MoveToAttribute(i);
            string str = "属性:" + reader.Name + "=" + reader.Value;
        }
        model.BookType = reader.GetAttribute(0);
        model.BookISBN = reader.GetAttribute(1);
    }

c#读取XML_第3张图片

2.2XmlTextWriter

XmlTextWriter写文件的时候,默认是覆盖以前的文件,如果此文件名不存在,它将创建此文件.首先设置一下,你要创建的XML文件格式,

XmlTextWriter myXmlTextWriter = new XmlTextWriter(@"..\..\Book1.xml", null);
   //使用 Formatting 属性指定希望将 XML 设定为何种格式。 这样,子元素就可以通过使用 Indentation 和 IndentChar 属性来缩进。
   myXmlTextWriter.Formatting = Formatting.Indented;

然后可以通过WriteStartElement和WriteElementString方法来创建元素,这两者的区别就是如果有子结点的元素,那么创建的时候就用WriteStartElement,然后去创建子元素,创建完毕后,要调用相应的WriteEndElement来告诉编译器,创建完毕,用WriteElementString来创建单个的元素,用WriteAttributeString来创建属性.如下:


  XmlTextWriter myXmlTextWriter = new XmlTextWriter(@"..\..\Book1.xml", null);
             //使用 Formatting 属性指定希望将 XML 设定为何种格式。 这样,子元素就可以通过使用 Indentation 和 IndentChar 属性来缩进。
             myXmlTextWriter.Formatting = Formatting.Indented;

             myXmlTextWriter.WriteStartDocument(false);
             myXmlTextWriter.WriteStartElement("bookstore");

             myXmlTextWriter.WriteComment("记录书本的信息");
             myXmlTextWriter.WriteStartElement("book");

             myXmlTextWriter.WriteAttributeString("Type", "选修课");
             myXmlTextWriter.WriteAttributeString("ISBN", "111111111");

             myXmlTextWriter.WriteElementString("author","张三");
             myXmlTextWriter.WriteElementString("title", "职业生涯规划");
             myXmlTextWriter.WriteElementString("price", "16.00");

             myXmlTextWriter.WriteEndElement();
             myXmlTextWriter.WriteEndElement();

             myXmlTextWriter.Flush();
             myXmlTextWriter.Close();

3.使用Linq to XML.

Linq是C#3.0中出现的一个新特性,使用它可以方便的操作许多数据源,也包括XML文件.使用Linq操作XML文件非常的方便,而且也比较简单.下面直接看代码,

先定义 一个方法显示查询出来的数据

private void showInfoByElements(IEnumerable elements)
      {
          List modelList = new List();
          foreach (var ele in elements)
          {
              BookModel model = new BookModel();
              model.BookAuthor = ele.Element("author").Value;
              model.BookName = ele.Element("title").Value;
              model.BookPrice = Convert.ToDouble(ele.Element("price").Value);
              model.BookISBN=ele.Attribute("ISBN").Value;
              model.BookType=ele.Attribute("Type").Value;

              modelList.Add(model);
          }
          dgvBookInfo.DataSource = modelList;
      }

3.1读取所有的数据

直接找到元素为book的这个结点,然后遍历读取所有的结果.

private void btnReadAll_Click(object sender, EventArgs e)
          {
              XElement xe = XElement.Load(@"..\..\Book.xml");
              IEnumerable elements = from ele in xe.Elements("book")
                                               select ele;
               showInfoByElements(elements);
           }

3.2插入一条数据

插入结点和属性都采用new的方法,如下:

private void btnInsert_Click(object sender, EventArgs e)
       {
           XElement xe = XElement.Load(@"..\..\Book.xml");
           XElement record = new XElement(
           new XElement("book",
           new XAttribute("Type", "选修课"),
           new XAttribute("ISBN","7-111-19149-1"),
           new XElement("title", "计算机操作系统"),
           new XElement("author", "7-111-19149-1"),
           new XElement("price", 28.00)));
           xe.Add(record);
           xe.Save(@"..\..\Book.xml");
           MessageBox.Show("插入成功!");
           btnReadAll_Click(sender, e);
       }

3.3 删除选中的数据

首先得到选中的那一行,通过ISBN号来找到这个元素,然后用Remove方法直接删除,如下:

private void btnDelete_Click(object sender, EventArgs e)
       {
           if (dgvBookInfo.CurrentRow != null)
           {
               //dgvBookInfo.CurrentRow.Cells[1]对应着ISBN号
               string id = dgvBookInfo.CurrentRow.Cells[1].Value.ToString();
               XElement xe = XElement.Load(@"..\..\Book.xml");
               IEnumerable elements = from ele in xe.Elements("book")
                                                where (string)ele.Attribute("ISBN") == id
                                                select ele;
               {
               if (elements.Count() > 0)
                   elements.First().Remove();
               }
               xe.Save(@"..\..\Book.xml");
               MessageBox.Show("删除成功!");
               btnReadAll_Click(sender, e);

           }
       }

3.4 删除所有的数据

与上面的类似,选出所有的数据,然后用Remove方法,如下:

  private void btnDeleteAll_Click(object sender, EventArgs e)
         {
             XElement xe = XElement.Load(@"..\..\Book.xml");
             IEnumerable elements = from ele in xe.Elements("book")
                                              select ele;
             if (elements.Count() > 0)
             {
                 elements.Remove();
             }
             xe.Save(@"..\..\Book.xml");
             MessageBox.Show("删除成功!");
             btnReadAll_Click(sender, e);
         }

3.5 修改某一记录

首先得到所要修改的某一个结点,然后用SetAttributeValue来修改属性,用ReplaceNodes来修改结点元素。如下:

  private void btnSave_Click(object sender, EventArgs e)
 {
     XElement xe = XElement.Load(@"..\..\Book.xml");
     if (dgvBookInfo.CurrentRow != null)
     {
         //dgvBookInfo.CurrentRow.Cells[1]对应着ISBN号
         string id = dgvBookInfo.CurrentRow.Cells[1].Value.ToString();
         IEnumerable element = from ele in xe.Elements("book")
                                         where ele.Attribute("ISBN").Value == id
                                         select ele;
         if (element.Count() > 0)
         {
             XElement first = element.First();
             ///设置新的属性
             first.SetAttributeValue("Type", dgvBookInfo.CurrentRow.Cells[0].Value.ToString());
             ///替换新的节点
             first.ReplaceNodes(
                      new XElement("title", dgvBookInfo.CurrentRow.Cells[2].Value.ToString()),  
                      new XElement("author", dgvBookInfo.CurrentRow.Cells[3].Value.ToString()),
                      new XElement("price", (double)dgvBookInfo.CurrentRow.Cells[4].Value) 
                      );
         }
         xe.Save(@"..\..\Book.xml");

         MessageBox.Show("修改成功!");
         btnReadAll_Click(sender, e);
     }
 }

4.完整代码:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Xml;

namespace BooksForms
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();

        }


        #region 读取所有图书信息


        /// 
        /// 读取所有图书信息
        /// 
        /// 
        /// 
        private void ReadAllBooks_Click(object sender, EventArgs e)
        {
            XmlDocument doc = new XmlDocument();
            XmlReaderSettings settings = new XmlReaderSettings();
            settings.IgnoreComments = true;//忽略文档里面的注释
            XmlReader reader = XmlReader.Create(@"D:\Book.xml", settings);
            doc.Load(reader);
            //doc.Load(@"D:\Book.xml");

            XmlNode xn = doc.SelectSingleNode("bookstore");
            XmlNodeList xnl = xn.ChildNodes;
            List bookModeList = new List();
            foreach (XmlNode xns in xnl)
            {
                try
                {
                    BookModel bookModel = new BookModel();
                    // 将节点转换为元素,便于得到节点的属性值
                    XmlElement xe = (XmlElement)xns;
                    // 得到Type和ISBN两个属性的属性值
                    bookModel.BookISBN = xe.GetAttribute("ISBN").ToString();
                    bookModel.BookType = xe.GetAttribute("Type").ToString();
                    // 得到Book节点的所有子节点
                    XmlNodeList xnl0 = xe.ChildNodes;
                    bookModel.BookName = xnl0.Item(0).InnerText;
                    bookModel.BookAuthor = xnl0.Item(1).InnerText;
                    bookModel.BookPrice = Convert.ToDouble(xnl0.Item(2).InnerText);
                    bookModeList.Add(bookModel);
                }
                catch (Exception)
                {

                    continue;
                }
            }
            reader.Close();//在此过程中需要关闭,不然文件会被占用
            this.dgvBookInfo.DataSource = bookModeList;

        }
        #endregion

        #region 新增一本书

        /// 
        /// 新增一本书
        /// 
        /// 
        /// 
        private void AddBookInfo_Click(object sender, EventArgs e)
        {
            ///加载文件并选出要结点:
            XmlDocument doc = new XmlDocument();
            doc.Load(@"D:\Book.xml");
            XmlNode xn = doc.SelectSingleNode("bookstore");

            //创建一个结点,并设置结点的属性:
            XmlElement xelKey = doc.CreateElement("book");
            XmlAttribute xelType = doc.CreateAttribute("Type");
            xelType.InnerText = "选修课";

            XmlAttribute xelType1 = doc.CreateAttribute("ISBN");
            xelType1.InnerText = "112-225-25";

            xelKey.SetAttributeNode(xelType);
            xelKey.SetAttributeNode(xelType1);

            //创建子结点:
            XmlElement title = doc.CreateElement("title");
            title.InnerText = "你必须知道的NET";
            XmlElement author = doc.CreateElement("author");
            author.InnerText = "YoungHaiqing";
            XmlElement price = doc.CreateElement("price");
            price.InnerText = "28";
            xelKey.AppendChild(title);
            xelKey.AppendChild(author);
            xelKey.AppendChild(price);

            //最后把book结点挂接在要结点上,并保存整个文件:
            xn.AppendChild(xelKey);
            doc.Save(@"D:\Book.xml");

            ReadAllBooks_Click("",new EventArgs());
            MessageBox.Show("新增成功");

        }
        #endregion

        #region 删除当前行图书
        /// 
        /// 删除当前行图书
        /// 
        /// 
        /// 
        private void DelBookInfo_Click(object sender, EventArgs e)
        {
            XmlDocument doc = new XmlDocument();
            doc.Load(@"D:\Book.xml");
            XmlElement xe = doc.DocumentElement;
            string strPath = string.Format("/bookstore/book[@ISBN=\"{0}\"]", this.dgvBookInfo.CurrentRow.Cells[1].Value.ToString());
            XmlElement selectXe = (XmlElement)xe.SelectSingleNode(strPath);
            selectXe.ParentNode.RemoveChild(selectXe);
            doc.Save(@"D:\Book.xml");


            ReadAllBooks_Click("", new EventArgs());
            MessageBox.Show("删除成功");

        }
        #endregion

        #region 更新当前行图书数据
        /// 
        /// 更新当前行图书数据
        /// 
        /// 
        /// 
        private void UpdateBookInfo_Click(object sender, EventArgs e)
        {
            XmlDocument doc = new XmlDocument();
            doc.Load(@"D:\Book.xml");
            XmlElement xe = doc.DocumentElement;
            string strPath = string.Format("/bookstore/book[@ISBN=\"{0}\"]", this.dgvBookInfo.CurrentRow.Cells[1].Value.ToString());

            XmlElement selectXe = (XmlElement)xe.SelectSingleNode(strPath);
            selectXe.SetAttribute("Type", dgvBookInfo.CurrentRow.Cells[0].Value.ToString());
            selectXe.GetElementsByTagName("title").Item(0).InnerText  = dgvBookInfo.CurrentRow.Cells[2].Value.ToString();
            selectXe.GetElementsByTagName("author").Item(0).InnerText = dgvBookInfo.CurrentRow.Cells[3].Value.ToString();
            selectXe.GetElementsByTagName("price").Item(0).InnerText  = dgvBookInfo.CurrentRow.Cells[4].Value.ToString();
            doc.Save(@"D:\Book.xml");


            ReadAllBooks_Click("", new EventArgs());
            MessageBox.Show("更新成功");

        }
        #endregion 删除当前行图书
    }

    /// 
    /// 图书信息类
    /// 
    public class BookModel
    {
        public BookModel()
        { }
        /// 
        /// 所对应的课程类型
        /// 
        private string bookType;

        public string BookType
        {
            get { return bookType; }
            set { bookType = value; }
        }

        /// 
        /// 书所对应的ISBN号
        /// 
        private string bookISBN;

        public string BookISBN
        {
            get { return bookISBN; }
            set { bookISBN = value; }
        }

        /// 
        /// 书名
        /// 
        private string bookName;

        public string BookName
        {
            get { return bookName; }
            set { bookName = value; }
        }

        /// 
        /// 作者
        /// 
        private string bookAuthor;

        public string BookAuthor
        {
            get { return bookAuthor; }
            set { bookAuthor = value; }
        }

        /// 
        /// 价格
        /// 
        private double bookPrice;

        public double BookPrice
        {
            get { return bookPrice; }
            set { bookPrice = value; }
        }
    }

}

http://www.cnblogs.com/a1656344531/archive/2012/11/28/2792863.html

你可能感兴趣的:(C#高级编程)