博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
封装好的实用的读写XML类---增删改查XML
阅读量:5781 次
发布时间:2019-06-18

本文共 10157 字,大约阅读时间需要 33 分钟。

1、创建一个类:XmlHelper

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Xml;using System.Windows.Forms;namespace WindowsFormsApplication14{    class XmlHelper    {        public XmlHelper()        {        }        ///         /// 读取数据        ///         /// 路径        /// 节点        /// 属性名,非空时返回该属性值,否则返回串联值        /// 
string
/************************************************** * 使用示列: * XmlHelper.Read(path, "/Node", "") * XmlHelper.Read(path, "/Node/Element[@Attribute='Name']", "Attribute") ************************************************/ public static string Read(string path, string node, string attribute) { string value = ""; try { XmlDocument doc = new XmlDocument(); doc.Load(path); XmlNode xn = doc.SelectSingleNode(node); value = (attribute.Equals("") ? xn.InnerText : xn.Attributes[attribute].Value); } catch { } return value; } /// /// 插入数据 /// /// 路径 /// 节点 /// 元素名,非空时插入新元素,否则在该元素中插入属性 /// 属性名,非空时插入该元素属性值,否则插入元素值 /// 值 ///
/************************************************** * 使用示列: * XmlHelper.Insert(path, "/Node", "Element", "", "Value") * XmlHelper.Insert(path, "/Node", "Element", "Attribute", "Value") * XmlHelper.Insert(path, "/Node", "", "Attribute", "Value") ************************************************/ public static void Insert(string path, string node, string element, string attribute, string value) { try { XmlDocument doc = new XmlDocument(); doc.Load(path); XmlNode xn = doc.SelectSingleNode(node); if (element.Equals("")) { if (!attribute.Equals("")) { XmlElement xe = (XmlElement)xn; xe.SetAttribute(attribute, value); } } else { XmlElement xe = doc.CreateElement(element); if (attribute.Equals("")) xe.InnerText = value; else xe.SetAttribute(attribute, value); xn.AppendChild(xe); } doc.Save(path); } catch { } } /// /// 修改数据 /// /// 路径 /// 节点 /// 属性名,非空时修改该节点属性值,否则修改节点值 /// 值 ///
/************************************************** * 使用示列: * XmlHelper.Insert(path, "/Node", "", "Value") * XmlHelper.Insert(path, "/Node", "Attribute", "Value") ************************************************/ public static void Update(string path, string node, string attribute, string value) { try { XmlDocument doc = new XmlDocument(); doc.Load(path); XmlNode xn = doc.SelectSingleNode(node); XmlElement xe = (XmlElement)xn; if (attribute.Equals("")) xe.InnerText = value; else xe.SetAttribute(attribute, value); doc.Save(path); } catch { } } /// /// 删除数据 /// /// 路径 /// 节点 /// 属性名,非空时删除该节点属性值,否则删除节点值 /// 值 ///
/************************************************** * 使用示列: * XmlHelper.Delete(path, "/Node", "") * XmlHelper.Delete(path, "/Node", "Attribute") ************************************************/ public static void Delete(string path, string node, string attribute) { try { XmlDocument doc = new XmlDocument(); doc.Load(path); XmlNode xn = doc.SelectSingleNode(node); XmlElement xe = (XmlElement)xn; //if (attribute.Equals("")) // xn.ParentNode.RemoveChild(xn); //else // xe.RemoveAttribute(attribute); xn.RemoveAll(); doc.Save(path); } catch { } } }}

 

2、窗体单击按钮调用代码

 

private void button1_Click(object sender, EventArgs e)        {            //删除元素            XmlHelper.Delete("F:\\XmlFile.xml", "/Root", "");            //表名            XmlHelper.Insert("F:\\XmlFile.xml", "/Root", "Table", "name", "m_C_User");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table[@name='m_C_User']", "", "TableEqualsForm", "False");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table[@TableEqualsForm='False']", "", "title", "用户报表");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table[@title='用户报表']", "", "pageDown", "森林海科技有限公司");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table", "Items", "", "");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items", "Item", "name", "UserNo");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@name='UserNo']", "", "Text", "用户编号");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@Text='用户编号']", "", "width", "20");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@name='UserNo'and @Text='用户编号'and @width='20']", "", "summary", "False");             XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items", "Item", "name", "UserName");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@name='UserName']", "", "Text", "用户姓名");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@Text='用户姓名']", "", "width", "20");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@name='UserName'and @Text='用户姓名'and @width='20']", "", "summary", "False");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items", "Item", "name", "Sex");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@name='Sex']", "", "Text", "性别");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@Text='性别']", "", "width", "20");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@name='Sex'and @Text='性别'and @width='20']", "", "summary", "False");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items", "Item", "name", "TelNum");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@name='TelNum']", "", "Text", "联系电话");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@Text='联系电话']", "", "width", "20");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@name='TelNum'and @Text='联系电话'and @width='20']", "", "summary", "False");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items", "Item", "name", "DeptName");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@name='DeptName']", "", "Text", "部门");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@Text='部门']", "", "width", "20");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@name='DeptName'and @Text='部门'and @width='20']", "", "summary", "False");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items", "Item", "name", "Headship");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@name='Headship']", "", "Text", "职位");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@Text='职位']", "", "width", "20");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/Table/Items/Item[@name='Headship'and @Text='职位'and @width='20']", "", "summary", "False");            //插入元素/属性            XmlHelper.Insert("F:\\XmlFile.xml", "/Root", "ReportFild", "name", "m_C_User");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild", "Items", "", "");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items", "Item", "name", "UserNo");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items/Item[@name='UserNo']", "", "value", "True");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items/Item[@name='UserNo'and @value='True']", "", "width", "100");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items", "Item", "name", "UserName");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items/Item[@name='UserName']", "", "value", "True");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items/Item[@name='UserName'and @value='True']", "", "width", "100");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items", "Item", "name", "Sex");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items/Item[@name='Sex']", "", "value", "True");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items/Item[@name='Sex'and @value='True']", "", "width", "100");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items", "Item", "name", "TelNum");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items/Item[@name='TelNum']", "", "value", "True");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items/Item[@name='TelNum'and @value='True']", "", "width", "100");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items", "Item", "name", "DeptName");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items/Item[@name='DeptName']", "", "value", "True");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items/Item[@name='DeptName'and @value='True']", "", "width", "100");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items", "Item", "name", "Headship");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items/Item[@name='Headship']", "", "value", "True");            XmlHelper.Insert("F:\\XmlFile.xml", "/Root/ReportFild/Items/Item[@name='Headship'and @value='True']", "", "width", "100");        }

 

3、XmlFile.xml写入结果:

 

转载地址:http://secyx.baihongyu.com/

你可能感兴趣的文章
XP 安装ORACLE
查看>>
八、 vSphere 6.7 U1(八):分布式交换机配置(vMotion迁移网段)
查看>>
php5编译安装常见错误和解决办法集锦
查看>>
ORACLE配置,修改tnsnames.ora文件实例
查看>>
我的友情链接
查看>>
JS中比较数字大小
查看>>
jQuery插件的开发
查看>>
基础,基础,还是基础之JAVA基础
查看>>
haproxy mysql实例配置
查看>>
MySQL 8.0 压缩包版安装方法
查看>>
JS prototype 属性
查看>>
iphone-common-codes-ccteam源代码 CCEncoding.m
查看>>
nginx中配置文件的讲解
查看>>
HTTP库Axios
查看>>
CentOS7下安装python-pip
查看>>
gen already exists but is not a source folder. Convert to a source folder or rename it 的解决办法...
查看>>
20个Linux服务器性能调优技巧
查看>>
填坑记:Uncaught RangeError: Maximum call stack size exceeded
查看>>
SpringCloud之消息总线(Spring Cloud Bus)(八)
查看>>
实时编辑
查看>>