这次使用操作Xml较为常用的方法:使用XMlreader和Xmlwriter

1:读取xml文件的数学和元素

XmlReaderSettings settings = new XmlReaderSettings();
            settings.IgnoreComments = true;
            settings.IgnoreWhitespace = true;

XmlReader reader = XmlReader.Create("Customer2.xml", settings);
            List<CustomerInfo> lists = new List<CustomerInfo>();

CustomerInfo cust = null;

while (reader.Read())
            {
                if (reader.NodeType == XmlNodeType.Element)
                {
                    switch (reader.Name)
                    {
                        case "row":
                            cust = new CustomerInfo();
                            if (reader.HasAttributes)
                            {
                                cust.AppId = reader.GetAttribute("AppID");
                                cust.Version = reader.GetAttribute("Version");
                            }
                            break;

case "CustomerID":
                            cust.CustomerID = reader.ReadString();
                            break;

case "CompanyName":
                            cust.CompanyName = reader.ReadString();
                            break;
                        case "ContactName":
            
                            cust.ContactName = reader.ReadString();
                            break;
                        case "ContactTitle":
   
                            cust.ContactTitle = reader.ReadString();
                            break;

case "Address":
                         
                            cust.Address = reader.ReadString();
                            break;

case "City":
                            cust.City = reader.ReadString();
                            break;

case "PostalCode":
                            cust.PostalCode = reader.ReadString();
                            break;
                        case "Country":
                            cust.Country = reader.ReadString();
                            break;
                        case "Phone":
                            cust.Phone = reader.ReadString();
                            break;
                        case "Fax":
                            cust.Fax = reader.ReadString();
                            lists.Add(cust);
                            break;
                        default:
                            break;

}
                }

}

2.创建文档-属性和元素

XmlWriterSettings settings = new XmlWriterSettings();
            settings.Indent = true;
            settings.NewLineOnAttributes = false;
            XmlWriter writer = XmlWriter.Create("CustomerNewElementArribute.xml", settings);
            writer.WriteStartDocument();
            writer.WriteStartElement("Table");

for (int i = 1; i < 10; i++)
            {
                writer.WriteStartElement("row");
                writer.WriteAttributeString("Version", "2.0");
                writer.WriteAttributeString("AppID", "111");
                writer.WriteElementString("CustomerID", "cmz" + i.ToString());
                writer.WriteElementString("CompanyName", "程沐喆" + i.ToString());
                writer.WriteElementString("ContactName", "Maria Anders" + i.ToString());
                writer.WriteElementString("ContactTitle", "Sales Representative" + i.ToString());
                writer.WriteElementString("Address", "Obere Str. 57" + i.ToString());
                writer.WriteElementString("City", "Berlin");
                writer.WriteElementString("PostalCode", "12209");
                writer.WriteElementString("Country", "Germany");
                writer.WriteElementString("Phone", "030-0074321");
                writer.WriteElementString("Fax", "030-0076545");
                writer.WriteEndElement();
            }

writer.WriteEndElement();
            writer.WriteEndDocument();
            writer.Flush();
            writer.Close();
                
        }

private void button7_Click(object sender, EventArgs e)
        {
            XmlWriterSettings settings = new XmlWriterSettings();
            settings.Indent = true;
            settings.NewLineOnAttributes = false;
            settings.Encoding = Encoding.UTF8;
            StringBuilder builder = new StringBuilder();
            XmlWriter writer = XmlWriter.Create(builder, settings);
            writer.WriteStartDocument();
            writer.WriteStartElement("Table");

for (int i = 1; i < 5; i++)
            {
                writer.WriteStartElement("row");
                writer.WriteAttributeString("Version", "2.0");
                writer.WriteAttributeString("AppID", "111");
                writer.WriteElementString("CustomerID", "cmz" + i.ToString());
                writer.WriteElementString("CompanyName", "程沐喆" + i.ToString());
                writer.WriteElementString("ContactName", "Maria Anders" + i.ToString());
                writer.WriteElementString("ContactTitle", "Sales Representative" + i.ToString());
                writer.WriteElementString("Address", "Obere Str. 57" + i.ToString());
                writer.WriteElementString("City", "Berlin");
                writer.WriteElementString("PostalCode", "12209");
                writer.WriteElementString("Country", "Germany");
                writer.WriteElementString("Phone", "030-0074321");
                writer.WriteElementString("Fax", "030-0076545");
                writer.WriteEndElement();
            }
            writer.WriteEndElement();
            writer.WriteEndDocument();
            writer.Flush();

writer.Close();

另外在介绍自己学习的使用xmlwriter写入StringBuiler和Stream

创建xml写入StringBuiler:

XmlWriterSettings settings = new XmlWriterSettings();
            settings.Indent = true;
            settings.NewLineOnAttributes = false;
            settings.Encoding = Encoding.UTF8;
            StringBuilder builder = new StringBuilder();
            XmlWriter writer = XmlWriter.Create(builder, settings);
            writer.WriteStartDocument();

writer.WriteStartElement("Table");

for (int i = 1; i < 5; i++)
            {
                writer.WriteStartElement("row");
                writer.WriteAttributeString("Version", "2.0");
                writer.WriteAttributeString("AppID", "111");
                writer.WriteElementString("CustomerID", "ALFKI" + i.ToString());
                writer.WriteElementString("CompanyName", "Alfreds Futterkiste" + i.ToString());
                writer.WriteElementString("ContactName", "Maria Anders" + i.ToString());
                writer.WriteElementString("ContactTitle", "Sales Representative" + i.ToString());
                writer.WriteElementString("Address", "Obere Str. 57" + i.ToString());
                writer.WriteElementString("City", "Berlin");
                writer.WriteElementString("PostalCode", "12209");
                writer.WriteElementString("Country", "Germany");
                writer.WriteElementString("Phone", "030-0074321");
                writer.WriteElementString("Fax", "030-0076545");
                writer.WriteEndElement();
            }
            writer.WriteEndElement();
            writer.WriteEndDocument();
            writer.Flush();
            writer.Close();

创建xml写入stream:

XmlWriterSettings settings = new XmlWriterSettings();
            settings.Indent = true;
            settings.NewLineOnAttributes = false;
            settings.Encoding = new UTF8Encoding(false);
            MemoryStream stream = new MemoryStream();
            XmlWriter writer = XmlWriter.Create(stream, settings);
            writer.WriteStartDocument();
            writer.WriteStartElement("Table");

for (int i = 1; i < 5; i++)
            {
                writer.WriteStartElement("row");
                writer.WriteAttributeString("Version", "2.0");
                writer.WriteAttributeString("AppID", "111");
                writer.WriteElementString("CustomerID", "ALFKI" + i.ToString());
                writer.WriteElementString("CompanyName", "Alfreds Futterkiste" + i.ToString());
                writer.WriteElementString("ContactName", "Maria Anders" + i.ToString());
                writer.WriteElementString("ContactTitle", "Sales Representative" + i.ToString());
                writer.WriteElementString("Address", "Obere Str. 57" + i.ToString());
                writer.WriteElementString("City", "Berlin");
                writer.WriteElementString("PostalCode", "12209");
                writer.WriteElementString("Country", "Germany");
                writer.WriteElementString("Phone", "030-0074321");
                writer.WriteElementString("Fax", "030-0076545");
                writer.WriteEndElement();
            }
            writer.WriteEndElement();
            writer.WriteEndDocument();
            writer.Flush();
            writer.Close();

C#操作XMl文件(2):使用XmlReader和XmlWriter实现读取和写入的更多相关文章

  1. Asp.Net 操作XML文件的增删改查 利用GridView

    不废话,直接上如何利用Asp.NET操作XML文件,并对其属性进行修改,刚开始的时候,是打算使用JS来控制生成XML文件的,但是最后却是无法创建文件,读取文件则没有使用了 index.aspx 文件 ...

  2. Java操作XML文件 dom4j 篇

    在项目中,我们很多都用到了xml文件,无论是参数配置还是与其它系统的数据交互.今天就来讲一下Java 中使用dom4j来操作XML文件. 我们需要引入的包: //文件包 import java.io. ...

  3. PHP操作XML文件学习笔记

    原文:PHP操作XML文件学习笔记 XML文件属于标签语言,可以通过自定义标签存储数据,其主要作用也是作为存储数据. 对于XML的操作包括遍历,生成,修改,删除等其他类似的操作.PHP对于XML的操作 ...

  4. Qt之QDomDocument操作xml文件-模拟ini文件存储

    一.背景 不得不说Qt是一个很强大的类库,不管是做项目还是做产品,Qt自身封装的东西就已经非常全面了,我们今天的这篇文章就是模拟了Qt读写ini文件的一个操作,当然是由于一些外力原因,我们决定自己来完 ...

  5. JAVA中通过Jaxp操作XML文件基础

    Java中有多种方式操作XML文件,目前讲一讲以SUN公司提供的DocumentBuilderFactory工厂类对象操作XML. 使用XML基本操作就是需要CRUD(增删改查),那么首先通过一个查询 ...

  6. WebAPI调用笔记 ASP.NET CORE 学习之自定义异常处理 MySQL数据库查询优化建议 .NET操作XML文件之泛型集合的序列化与反序列化 Asp.Net Core 轻松学-多线程之Task快速上手 Asp.Net Core 轻松学-多线程之Task(补充)

    WebAPI调用笔记   前言 即时通信项目中初次调用OA接口遇到了一些问题,因为本人从业后几乎一直做CS端项目,一个简单的WebAPI调用居然浪费了不少时间,特此记录. 接口描述 首先说明一下,基于 ...

  7. C#操作xml文件:使用XmlDocument 实现读取和写入

    XML文件是一种常用的文件格式,例如WinForm里面的app.config以及Web程序中的web.config文件,还有许多重要的场所都有它的身影.Xml是Internet环境中跨平台的,依赖于内 ...

  8. 利用XmlDocument操作XML文件

    利用XmlDocument可以方便的操作XML文件. .操作XML文件基本方法 ()添加对System.Xml的引用,并使用using语句添加引用: ()假设要读取的XML文件如下: <?xml ...

  9. C#基础知识---Linq操作XML文件

    概述 Linq也就是Language Integrated Query的缩写,即语言集成查询,是微软在.Net 3.5中提出的一项新技术. Linq主要包含4个组件---Linq to Objects ...

随机推荐

  1. mysql 基础整合大全

    mysql  数据库操作: 创建数据库: create database db_sanguo charset utf8; 切进db_sanguo use db_sanguo 删除数据库: drop d ...

  2. BZOJ2961: 共点圆(CDQ分治+凸包)

    题面 传送门 题解 这题解法真是多啊--据说可以圆反演转化为动态插入半平面并判断给定点是否在半平面交中,或者化一下改成给定点判断是否所有点都在某一个半平面内-- 鉴于圆反演我也不会,这里讲一下直接推的 ...

  3. Linux中tail指令详解

    linux tail命令用途是依照要求将指定的文件的最后部分输出到标准设备,通常是终端,通俗讲来,就是把某个档案文件的最后几行显示到终端上,假设该档案有更新,tail会自己主动刷新,确保你看到最新的档 ...

  4. 【flask macro】No caller defined

    https://segmentfault.com/q/1010000005352059/a-1020000005352912 先码着 有时间了再换成caller() 先用老方法吧...

  5. 【Quartz】解密properties配置文件中的账号密码

    在配置quartz时,为了保密某些信息(特别是账号密码),通常会使用密文.那么在实际使用这些配置信息时,需要进行解密.本文提供一种解密方法如下: (1)假设在properties文件中加密了账号密码 ...

  6. day2: python3.5学习——逻辑判断

    1. 简单的用户名和密码输入 username = "Helen"password = "123abc" _username = input("use ...

  7. python之守护进程

    主进程创建子进程,然后将该进程设置成守护自己的进程,守护进程就好比崇祯皇帝身边的老太监,崇祯皇帝已死老太监就跟着殉葬了. 关于守护进程需要强调两点: 其一:守护进程会在主进程代码执行结束后就终止 其二 ...

  8. Ubuntu 16.04防火墙

    防火墙(ufw) 说明:简单版本的防火墙,底层依赖于iptables. 安装:sudo apt-get install ufw 查看状态:sudo ufw status 开启/关闭:sudo ufw ...

  9. mfix中输出DEM颗粒的固相速度到网格

    基于mfix-19.1.2版本 方法一:直接输出差值网格固相速度 注:这种方式只适用于garg 2012颗粒差值格式在DEM中,默认是无法输出固相速度的网格值的: 但是通过搜索des文件夹下V_s关键 ...

  10. Smarty <= 3.1.32 Remote Code execution(CVE-2017-1000480)

    Smarty介绍   smarty是一个php模板引擎,其项目地址:https://github.com/smarty-php/smarty 测试环境搭建   下载:https://github.co ...