16
4月
2020

C#快速上手XML增删查改

XML,可扩展标记语言,是一种用于标记电子文件使其具有结构性的标记语言。在实际应用中,我们可以用XML存储用户资料、产品参数和加密数据等信息,一个架构清晰的XML文档可以帮助程序员快速定位要查找的信息哦!今天我将通过实例教大家如何快速上手XML的基本操作(增删查改)。

1.创建XML文档

XML文档的每个节点都拥有包含着关于节点某些信息的属性,这些属性是:nodeName(节点名称)、nodeValue(节点值)和nodeType(节点类型)。这里我们建立一个由根节点、子节点和节点信息组成的三级架构的XML文档存储参数信息,其中Parameter是根节点、Info是子节点、节点信息包含Code、Name和Authority等。

/// <summary>
       /// 创建XML的方法
       /// </summary>
       /// <param name="sender"></param>
       /// <param name="e"></param>
       private void Button5_Click(object sender, EventArgs e)
       {
           //创建一个XML文档
           XmlDocument doc = new XmlDocument();
           //创建第一行描述信息
           XmlDeclaration dec = doc.CreateXmlDeclaration("1.0", "utf-8", null);
           //将创建的第一行描述信息添加到文档中
           doc.AppendChild(dec);

           //给文档添加根节点
           XmlElement Parameter = doc.CreateElement("Parameter");
           doc.AppendChild(Parameter);

           //添加子节点信息
           XmlElement Info = doc.CreateElement("Info");
           Info.SetAttribute("id", textBox1.Text);
           Parameter.AppendChild(Info);

           XmlElement Code = doc.CreateElement("Code");
           Code.InnerText = textBox1.Text;
           Info.AppendChild(Code);

           XmlElement Name = doc.CreateElement("Name");
           Name.InnerText = textBox2.Text;
           Info.AppendChild(Name);

           XmlElement Authority = doc.CreateElement("Authority");
           Authority.InnerText = textBox3.Text;
           Info.AppendChild(Authority);

           XmlElement Max = doc.CreateElement("Max");
           Max.InnerText = textBox4.Text;
           Info.AppendChild(Max);

           XmlElement Min = doc.CreateElement("Min");
           Min.InnerText = textBox5.Text;
           Info.AppendChild(Min);

           XmlElement Default = doc.CreateElement("Default");
           Default.InnerText = textBox6.Text;
           Info.AppendChild(Default);

           doc.Save("ParameterInfo.xml");
           showXML();
           MessageBox.Show("创建成功");
       }

运行后,在bin目录创建了一个名为ParameterInfo的XML文档,其结构如图1所示:

guide1

图1-XML文档架构

2.添加子节点

根据XML文档架构,分别给Info id、Code、Name、Authority、Max、Min和Default等属性赋值,从而添加新的Info子节点。

/// <summary>
       /// 添加子节点的方法
       /// </summary>
       /// <param name="sender"></param>
       /// <param name="e"></param>
       private void Button1_Click(object sender, EventArgs e)
       {
           XmlDocument doc = new XmlDocument();
           //首先判断文件是否存在,如果存在则追加否则在创建一个
           if (File.Exists("ParameterInfo.xml"))
           {
               //加载
               doc.Load("ParameterInfo.xml");

               //获取根节点,给根节点添加子节点
               XmlElement Parameter = doc.DocumentElement;
               XmlElement Info = doc.CreateElement("Info");
               Info.SetAttribute("id", textBox7.Text);
               Parameter.AppendChild(Info);

               XmlElement Code = doc.CreateElement("Code");
               Code.InnerText = textBox7.Text;
               Info.AppendChild(Code);

               XmlElement Name = doc.CreateElement("Name");
               Name.InnerText = textBox8.Text;
               Info.AppendChild(Name);

               XmlElement Authority = doc.CreateElement("Authority");
               Authority.InnerText = textBox9.Text;
               Info.AppendChild(Authority);

               XmlElement Max = doc.CreateElement("Max");
               Max.InnerText = textBox10.Text;
               Info.AppendChild(Max);

               XmlElement Min = doc.CreateElement("Min");
               Min.InnerText = textBox11.Text;
               Info.AppendChild(Min);

               XmlElement Default = doc.CreateElement("Default");
               Default.InnerText = textBox12.Text;
               Info.AppendChild(Default);

               doc.Save("ParameterInfo.xml");
               showXML();
               MessageBox.Show("添加成功");
           }
           else
           {
               MessageBox.Show("尚未创建ParameterInfo文档,无法添加根节点!");
           }
       }

3.删除子节点

实例已将XML信息绑定到dataGridView中,因此可以通过选中dataGridView中的某一行获取该行的Info id从而删除指定的子节点信息。

/// <summary>
       /// 删除子节点的方法
       /// </summary>
       /// <param name="sender"></param>
       /// <param name="e"></param>
       private void Button2_Click(object sender, EventArgs e)
       {

           // 删除指定的行数据
           //获得当前选中行的ID
           string id = dataGridView1.SelectedRows[0].Cells[0].Value.ToString();
           //根据ID进行删除
           XmlDocument doc = new XmlDocument();
           doc.Load("ParameterInfo.xml");
           XmlElement parameter = doc.DocumentElement;
           //获得要删除的节点
           XmlNode xn = parameter.SelectSingleNode("/Parameter/Info[@id=" + id + "]");
           //通过父节点移除子节点,包括子节点下面的节点
           parameter.RemoveChild(xn);

           doc.Save("ParameterInfo.xml");
           showXML();
           MessageBox.Show("删除成功!");
       }

4.查找XML信息

通过轮询遍历XML的节点信息,将各子节点拼接显示到TexBox中,实际应用中还可以稍作修改精确定位节点信息,这里暂时偷个懒~

/// <summary>
        /// 查询XML信息的方法
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void Button3_Click(object sender, EventArgs e)
        {
            XmlDocument doc = new XmlDocument();
            if (File.Exists("ParameterInfo.xml"))
            {
                doc.Load("ParameterInfo.xml");
                // 获取根节点
                XmlElement parameterElement = doc.DocumentElement;
                XmlNodeList parameterChildr = parameterElement.ChildNodes;
                foreach (XmlNode item in parameterChildr)
                {
                    textBox19.Text += "节点名称:" + item.Name + "  节点的 InnerText :" + item.InnerText + "\r\n";
                }
            }
            else
            {
                MessageBox.Show("ParameterInfo.xml文件不存在!");
            }
            doc.Save("ParameterInfo.xml");
        }

5.修改子节点

根据Info id定位需要修改的子节点,对Info id、Code、Name、Authority、Max、Min和Default等属性重新赋值。

/// <summary>
       /// 修改子节点的方法
       /// </summary>
       /// <param name="sender"></param>
       /// <param name="e"></param>
       private void Button4_Click(object sender, EventArgs e)
       {

           XmlDocument doc = new XmlDocument();
           doc.Load("ParameterInfo.xml");
           XmlElement parameter = doc.DocumentElement;
           //根据ID修改其它值
           string id = textBox13.Text;
           XmlNode xn = parameter.SelectSingleNode("/Parameter/Info[@id=" + id + "]");
           xn["Code"].InnerText = textBox13.Text;
           xn["Name"].InnerText = textBox14.Text;
           xn["Authority"].InnerText = textBox15.Text;
           xn["Max"].InnerText = textBox16.Text;
           xn["Min"].InnerText = textBox17.Text;
           xn["Default"].InnerText = textBox18.Text;

           doc.Save("ParameterInfo.xml");
           showXML();
           MessageBox.Show("修改成功!");
       }

6.操作教程

1)创建XML文档

guide2

图2-创建XML文档

2)添加子节点

guide3

图3-添加子节点

3)修改子节点

guide4

图4-修改子节点

4)查询XML文档

点击”查询”按钮,TextBox中自动生成节点信息。

5)删除子节点

选中dataGridView中需要删除的行,点击”删除”按钮,即可删除指定节点。


代码全文:

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


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

        DataSet dataSet = new DataSet();//声明此数据集,存储读取出的XML数据

        /// <summary>
        /// 创建XML的方法
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void Button5_Click(object sender, EventArgs e)
        {
            //创建一个XML文档
            XmlDocument doc = new XmlDocument();
            //创建第一行描述信息
            XmlDeclaration dec = doc.CreateXmlDeclaration("1.0", "utf-8", null);
            //将创建的第一行描述信息添加到文档中
            doc.AppendChild(dec);

            //给文档添加根节点
            XmlElement Parameter = doc.CreateElement("Parameter");
            doc.AppendChild(Parameter);

            //添加子节点信息
            XmlElement Info = doc.CreateElement("Info");
            Info.SetAttribute("id", textBox1.Text);
            Parameter.AppendChild(Info);

            XmlElement Code = doc.CreateElement("Code");
            Code.InnerText = textBox1.Text;
            Info.AppendChild(Code);

            XmlElement Name = doc.CreateElement("Name");
            Name.InnerText = textBox2.Text;
            Info.AppendChild(Name);

            XmlElement Authority = doc.CreateElement("Authority");
            Authority.InnerText = textBox3.Text;
            Info.AppendChild(Authority);

            XmlElement Max = doc.CreateElement("Max");
            Max.InnerText = textBox4.Text;
            Info.AppendChild(Max);

            XmlElement Min = doc.CreateElement("Min");
            Min.InnerText = textBox5.Text;
            Info.AppendChild(Min);

            XmlElement Default = doc.CreateElement("Default");
            Default.InnerText = textBox6.Text;
            Info.AppendChild(Default);

            doc.Save("ParameterInfo.xml");
            showXML();
            MessageBox.Show("创建成功");
        }

        /// <summary>
        /// 添加子节点的方法
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void Button1_Click(object sender, EventArgs e)
        {
            XmlDocument doc = new XmlDocument();
            //首先判断文件是否存在,如果存在则追加否则在创建一个
            if (File.Exists("ParameterInfo.xml"))
            {
                //加载
                doc.Load("ParameterInfo.xml");

                //获取根节点,给根节点添加子节点
                XmlElement Parameter = doc.DocumentElement;
                XmlElement Info = doc.CreateElement("Info");
                Info.SetAttribute("id", textBox7.Text);
                Parameter.AppendChild(Info);

                XmlElement Code = doc.CreateElement("Code");
                Code.InnerText = textBox7.Text;
                Info.AppendChild(Code);

                XmlElement Name = doc.CreateElement("Name");
                Name.InnerText = textBox8.Text;
                Info.AppendChild(Name);

                XmlElement Authority = doc.CreateElement("Authority");
                Authority.InnerText = textBox9.Text;
                Info.AppendChild(Authority);

                XmlElement Max = doc.CreateElement("Max");
                Max.InnerText = textBox10.Text;
                Info.AppendChild(Max);

                XmlElement Min = doc.CreateElement("Min");
                Min.InnerText = textBox11.Text;
                Info.AppendChild(Min);

                XmlElement Default = doc.CreateElement("Default");
                Default.InnerText = textBox12.Text;
                Info.AppendChild(Default);

                doc.Save("ParameterInfo.xml");
                showXML();
                MessageBox.Show("添加成功");
            }
            else
            {
                MessageBox.Show("尚未创建ParameterInfo文档,无法添加根节点!");
            }
        }

        /// <summary>
        /// 修改子节点的方法
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void Button4_Click(object sender, EventArgs e)
        {

            XmlDocument doc = new XmlDocument();
            doc.Load("ParameterInfo.xml");
            XmlElement parameter = doc.DocumentElement;
            //根据ID修改其它值
            string id = textBox13.Text;
            XmlNode xn = parameter.SelectSingleNode("/Parameter/Info[@id=" + id + "]");
            xn["Code"].InnerText = textBox13.Text;
            xn["Name"].InnerText = textBox14.Text;
            xn["Authority"].InnerText = textBox15.Text;
            xn["Max"].InnerText = textBox16.Text;
            xn["Min"].InnerText = textBox17.Text;
            xn["Default"].InnerText = textBox18.Text;

            doc.Save("ParameterInfo.xml");
            showXML();
            MessageBox.Show("修改成功!");
        }

        /// <summary>
        /// 删除子节点的方法
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void Button2_Click(object sender, EventArgs e)
        {

            // 删除指定的行数据
            //获得当前选中行的ID
            string id = dataGridView1.SelectedRows[0].Cells[0].Value.ToString();
            //根据ID进行删除
            XmlDocument doc = new XmlDocument();
            doc.Load("ParameterInfo.xml");
            XmlElement parameter = doc.DocumentElement;
            //获得要删除的节点
            XmlNode xn = parameter.SelectSingleNode("/Parameter/Info[@id=" + id + "]");
            //通过父节点移除子节点,包括子节点下面的节点
            parameter.RemoveChild(xn);

            doc.Save("ParameterInfo.xml");
            showXML();
            MessageBox.Show("删除成功!");
        }

        /// <summary>
        /// dataGridView显示XML信息的方法
        /// </summary>
        private void showXML()
        {
            if (File.Exists("ParameterInfo.xml"))
            {
                //读取XML文件信息
                dataSet.Clear();
                dataSet.ReadXml("ParameterInfo.xml");
                dataGridView1.DataSource = dataSet.Tables[0].DefaultView;
            }
            else
            {
                ;
            }
        }

        private void Form1_Load(object sender, EventArgs e)
        {
            showXML();
        }

        /// <summary>
        /// 查询XML信息的方法
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void Button3_Click(object sender, EventArgs e)
        {
            XmlDocument doc = new XmlDocument();
            if (File.Exists("ParameterInfo.xml"))
            {
                doc.Load("ParameterInfo.xml");
                // 获取根节点
                XmlElement parameterElement = doc.DocumentElement;
                XmlNodeList parameterChildr = parameterElement.ChildNodes;
                foreach (XmlNode item in parameterChildr)
                {
                    textBox19.Text += "节点名称:" + item.Name + "  节点的 InnerText :" + item.InnerText + "\r\n";
                }
            }
            else
            {
                MessageBox.Show("ParameterInfo.xml文件不存在!");
            }
            doc.Save("ParameterInfo.xml");
        }

        private void Button6_Click(object sender, EventArgs e)
        {
            System.Diagnostics.Process.Start("https://www.daboke.com");//欢迎访问大博客,探索更多编程实战案例!
        }

        private void Button7_Click(object sender, EventArgs e)
        {
            System.Diagnostics.Process.Start("https://www.daboke.com/program/xmlsample");//原文链接!
        }
    }
}

代码链接:

xmlSample

原文链接:

https://www.daboke.com/program/xmlsample.html

You may also like...

发表评论

邮箱地址不会被公开。

微信 OR 支付宝 扫描二维码
为本文作者 打个赏
pay_weixin pay_weixin
最喜欢你一言不合就打赏的样子了^_^