linq to xml 简单的增、删、改、查、保存xml文件操作

using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
using System.IO;
using System.Xml;

namespace test
{
    public partial class xmlDemo : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {

        }

        //使用XmlDocument创建xml文件
        protected void Button1_Click(object sender, EventArgs e)
        {
            string dirPath = Server.MapPath("/xml");

            DirectoryInfo dir = new DirectoryInfo(dirPath);

            if (!dir.Exists)
            {
                dir.Create();
            }

            //创建xml文件
            XmlDocument xdoc = new XmlDocument();

            //创建xml描述
            XmlDeclaration xdec = xdoc.CreateXmlDeclaration("1.0", "utf-8", null);
            xdoc.AppendChild(xdec);

            //创建xml跟节点

            XmlElement xroot = xdoc.CreateElement("persons");
            xdoc.AppendChild(xroot);

            //创建节点

            XmlElement xper = xdoc.CreateElement("person");
            xroot.AppendChild(xper);

            //对person节点设置属性
            xper.SetAttribute("id", "0001");

            //创建person节点下的子节点

            //person节点下创建name节点
            XmlElement xname = xdoc.CreateElement("name");
            xper.AppendChild(xname);

            XmlText textName = xdoc.CreateTextNode("test");
            xname.AppendChild(textName);

            //person节点下创建age节点
            XmlElement xage = xdoc.CreateElement("age");
            xper.AppendChild(xage);

            XmlText textAge = xdoc.CreateTextNode("20");
            xage.AppendChild(textAge);

            //person节点下创建sex节点
            XmlElement xsex = xdoc.CreateElement("sex");
            xper.AppendChild(xsex);

            XmlText textsex = xdoc.CreateTextNode("男");
            xsex.AppendChild(textsex);

            //保存xml文件
            xdoc.Save(dirPath+"/"+"person.xml");

            Response.Write("创建xml文件成功");

        }

        //使用linq to xml创建xml文件
        protected void Button2_Click(object sender, EventArgs e)
        {
            string dirPath = Server.MapPath("/xml");

            DirectoryInfo dir = new DirectoryInfo(dirPath);

            if (!dir.Exists)
            {
                dir.Create();
            }

            XDocument xdoc = new XDocument();

            //使用XDocument 可以不需要document描述

            //创建跟节点
            XElement root = new XElement("root");
            //添加跟节点
            xdoc.Add(root);

            //创建person节点

            XElement per = new XElement("person");
            //添加person节点
            root.Add(per);

            //创建属性节点
            XAttribute xId = new XAttribute("id", "0002222");

            //name节点
            XElement name = new XElement("name", "test");
            //age节点
            XElement age = new XElement("age", "22");
            //sex节点
            XElement sex = new XElement("sex", "男");

            //对person节点添加id属性 以及name sex age节点
            per.Add(xId,name, sex, age);

            //保存linq to xml 文件
            xdoc.Save(dirPath + "/" + "linqToXml.xml");

            Response.Write("linq to xml保存文件成功");

        }

        //使用linq to xml 批量添加person节点
        //xDocument.Root.Add()  批量添加
        protected void Button3_Click(object sender, EventArgs e)
        {
            string dirPath = Server.MapPath("/xml");

            DirectoryInfo dir = new DirectoryInfo(dirPath);

            if (!dir.Exists)
            {
                dir.Create();
            }

            XDocument xdoc = new XDocument();

            //使用XDocument 可以不需要document描述

            //创建跟节点

            XElement root = new XElement("root");

            xdoc.Add(root);

            Random r = new Random();

            for (int i = 1; i <= 100;i++ )
            {
                //person节点
                XElement per = new XElement("person");
                //id属性
                XAttribute xId = new XAttribute("id", i);
                //name
                XElement name = new XElement("name","test"+i);
                //age
                XElement age = new XElement("age",r.Next(18,30));
                //sex
                XElement sex = new XElement("sex", "男女"[r.Next(2)]);

                per.Add(xId, name, sex, age);

                xdoc.Root.Add(per);

            }

            //保存linq to xml 文件
            xdoc.Save(dirPath + "/" + "personList.xml");

            Response.Write("linq to xml批量添加成功");
        }

        //linq to xml 查找节点
        protected void Button5_Click(object sender, EventArgs e)
        {
            string path = Server.MapPath("/xml/personList.xml");

            XDocument xdoc = XDocument.Load(path);

            var query = xdoc.DescendantNodes().Where(

                    el => {

                        //将el转为XElement对象
                        XElement xe = el as XElement;
                        if (xe == null)
                        {
                            return false;
                        }

                        //找到age节点
                        XElement xAge = xe.Element("age");
                        //找到sex节点
                        XElement xSex = xe.Element("sex");
                        if(xAge !=null && xSex !=null)
                        {
                            int age = Convert.ToInt32(xAge.Value);
                            string sex = xSex.Value;
                            if (age >= 20 && age <= 25 && sex == "女")
                            {
                                return true;
                            }

                        }
                        return false;
                    }

                );

            //将查到的节点保存到xml文件中
            string savePath = Server.MapPath("/xml/search.xml");

            XDocument saveXdoc = new XDocument();

            XElement root = new XElement("root");

            saveXdoc.Add(root);

            root.Add(query);

            saveXdoc.Save(savePath);

            Response.Write("linq to xml查找成功");
        }

        //linq to xml 修改节点
        protected void Button4_Click(object sender, EventArgs e)
        {
            string path = Server.MapPath("/xml/personList.xml");
            XDocument xdoc = XDocument.Load(path);

            var query = from p in xdoc.Descendants("person")
                        where Convert.ToInt32(p.Attribute("id").Value) ==1
                        select p;

           var  first = query.FirstOrDefault();

           if (first != null)
            {

                XElement searchElement = first as XElement;

                XElement xname = searchElement.Element("name");
                xname.Value = "刘德华";

                xdoc.Save(path);

                Response.Write("linq to xml修改成功");

            }
        }

        //linq to xml 添加节点
        protected void Button6_Click(object sender, EventArgs e)
        {
            string path = Server.MapPath("/xml/personList.xml");

            XDocument xdoc = XDocument.Load(path);
            //找到根节点
            XElement root = xdoc.Element("root");

            XElement xPer = new XElement("person");

            XAttribute xid = new XAttribute("id", "9999");

            XElement xName = new XElement("name","张学友");

            XElement xSex = new XElement("sex","男");

            XElement xAge = new XElement("age","99");

            root.Add(xPer);

            xPer.Add(xPer, xid, xName, xAge, xSex);

            xdoc.Save(path);

            Response.Write("添加成功");

        }

        //linq to xml 删除节点
        protected void Button7_Click(object sender, EventArgs e)
        {
            string path = Server.MapPath("/xml/personList.xml");
            XDocument xdoc = XDocument.Load(path);

            var query = from p in xdoc.Descendants("person")
                        where Convert.ToInt32(p.Attribute("id").Value) == 1
                        select p;

            var first = query.FirstOrDefault();

            if (first != null)
            {

                XElement searchElement = first as XElement;

                searchElement.Remove();

                xdoc.Save(path);

                Response.Write("linq to xml删除成功");

            }
        }

    }
}
时间: 2024-10-15 15:54:51

linq to xml 简单的增、删、改、查、保存xml文件操作的相关文章

Python---MySQL数据库之四大操作(增 删 改 查)

一.对数据库,表,记录---四大操作(增 删 改 查) 1.操作数据库 (1)对数据库(文件夹):进行增加操作 Create  database  库名; 例:  Create  database  db7 ; 查询库: show  databases; 结果: +-----------------------------+ | Database                   | +----------------------------+ | information_schema | |

ADO.NET 增 删 改 查

ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访问技术的基础 连接数据库基本格式:需要两个类1.数据库连接类 SqlConnection2.数据库操作类 SqlCommand 1.连接数据库写连接字符串,立马就要想到有4点要写完,1.连接哪台服务器,2.连接哪个数据库,3.连接用户名,4.密码string sql = "server=.(服务器i

数据库基础学习4--表格的 增 删 改 查(简单查询与高级查询)

一.增 C:create 增加,创建,向数据库里面添加数据. insert into Fruit values('K009','苹果',3.0,'高青',90,'') insert into Fruit(Ids,Name,Price,Source,Numbers) values('K010','苹果',3.0,'高青',90) 二.改 U:update修改,从数据库表里面修改数据. update Fruit set Source='烟台' where Ids='K001' 三.删 D:delet

oracle 11g 建库 建表 增 删 改 查 约束

一.建库 1.(点击左上角带绿色+号的按钮) 2.(进入这个界面,passowrd为密码.填写完后点击下面一排的Test按钮进行测试,无异常就点击Connect) 二.建表 1-1. create table 表名1( Tid number(4) --primary key 列级约束(主键), Tname varchar(10) --ont null  非空约束,只能定义在列级约束, Tsex varchar2(2)--check (tsex='男'  or  tsex='女') 检查约束, T

SQL 增/删/改/查 (总结)

1.增 INSERT  INTO  表名  VALUES (" "," ") ; INSERT INTO 表名(字段)  VALUES(" "); 2. 删 DELETE   FROM 表名  WHERE  ... 3.改 UPDATE  表名 SET   ... WHERE  ... 4.查 SELECT × FROM  表名 ORDER BY ...

1-24.list的增,删,改,查

增: 1.append(通过元素增加,默认加在最后print(a.append('hgf'))) 2.extend( 迭代的去增,就是把字符串的字符逐个去给这个列表加上去) 3.insert((按照索引去增加,前为索引,后为增加的字) 删: 1,pop(通过位置索引去删除) 2.del (通过索引,切片删除) 3.clear(清空列表) 4.remove(通过元素去删除) #返回值是什么意思? 改: a[]='i' print() 查: for i in a: print(a) 其他列表 1.s

好用的SQL TVP~~独家赠送[增-删-改-查]的例子

一.什么是TVP? 表值参数Table-Value Parameter (TVP) 提供一种将客户端应用程序中的多行数据封送到 SQL Server 的简单方式,而不需要多次往返或特殊服务器端逻辑来处理数据. 您可以使用表值参数来包装客户端应用程序中的数据行,并使用单个参数化命令将数据发送到服务器. 传入的数据行存储在一个表变量中,然后您可以通过使用 Transact-SQL 对该表变量进行操作. 可以使用标准的 Transact-SQL SELECT 语句来访问表值参数中的列值. 简单点说就是

php基础:数据库的含义和基本操作 增 删 改 查

//数据库是帮我们管理数据的一个软件,我们将数据给他,放进数据库里.他能很稳妥的帮我们管理起来,且效率很高.//php的大部分工作就是  php->连接数据库->写入数据->查出数据->格式化数据->显示出来,//数据库管理数据是以表的形式组成的,多行多列,表头声明好了,一个表创建好了,剩下的就是往里面添加数据 多张表放在一个文件夹里面就形成了库  mysql服务器帮我们管理多个库C:\wamp\bin\mysql\mysql5.6.12\data   数据库中的数据放在这个

Android 增,删,改,查 通讯录中的联系人

一.权限 操作通讯录必须在AndroidManifest.xml中先添加2个权限, <uses-permission android:name="android.permission.READ_CONTACTS"></uses-permission> <uses-permission android:name="android.permission.WRITE_CONTACTS"></uses-permission>

MyBatis的配置与使用(增,删,改,查)

---恢复内容开始--- Mybatis入门介绍 一.MyBatis介绍 什么是MyBtis? MyBatis 是一个简化和实现了 Java 数据持久化层(persistence layer)的开源框架,它抽象了大量的 JDBC 冗余代 码,并提供了一个简单易用的 API 和数据库交互. MyBatis 的前身是 iBATIS,iBATIS 于 2002 年由 Clinton Begin 创建.MyBatis 3 是 iBATIS 的全新设计,支持 注解和 Mapper. MyBatis 流行的