一、简单介绍

using System.Xml;
//初始化一个xml实例
XmlDocument xml=new XmlDocument();

//导入指定xml文件
xml.Load(path);
xml.Load(HttpContext.Current.Server.MapPath("~/file/bookstore.xml"));

//指定一个节点
XmlNode root=xml.SelectSingleNode("/root");

//获取节点下所有直接子节点
XmlNodeList childlist=root.ChildNodes;

//判断该节点下是否有子节点
root.HasChildNodes;

//获取同名同级节点集合
XmlNodeList nodelist=xml.SelectNodes("/Root/News");

//生成一个新节点
XmlElement node=xml.CreateElement("News");

//将节点加到指定节点下,作为其子节点
root.AppendChild(node);

//将节点加到指定节点下某个子节点前
root.InsertBefore(node,root.ChildeNodes[i]);

//为指定节点的新建属性并赋值
node.SetAttribute("id","11111");

//为指定节点添加子节点
root.AppendChild(node);

//获取指定节点的指定属性值
string id=node.Attributes["id"].Value;

//获取指定节点中的文本
string content=node.InnerText;

//保存XML文件
string path=Server.MapPath("~/file/bookstore.xml");
xml.Save(path);
//or use :xml.Save(HttpContext.Current.Server.MapPath("~/file/bookstore.xml"));

二、具体实例

新建xml文档 名字为userinfo.xml:

内容:

<UserInfo>
<Persion id="001">
<name>李鹏</name>
<gender>男</gender>
</Persion>
<Persion id="002">
<name>小明</name>
<gender>男</gender>
</Persion>
<Persion id="003">
<name>小花</name>
<gender>女</gender>
</Persion>
</UserInfo>
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Xml;
using System.IO; namespace WebApplication1
{
public partial class Test : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
string path;
path = Server.MapPath("file/userinfo.xml");
if (File.Exists(path))
{
lblFile.Text = "文件存在";
}
//首先加载这个xml文档
XmlDocument xml = new XmlDocument();
xml.Load(path); #region 一:节点的加载
//获取userinfo节点
XmlNode node = xml.SelectSingleNode("UserInfo");
//获取Persion节点集合
XmlNodeList nodeList = xml.SelectNodes("/UserInfo/Persion"); //获取Persion节点的属性为id的value
foreach (XmlNode aN in nodeList)
{
XmlElement axe = (XmlElement)aN;
//第一种方法
string str = axe.GetAttribute("id");
//第二种方法
string str1 = axe.Attributes["id"].Value; } //获取到第一个persion节点的子节点
XmlNodeList nodeList2 = node.FirstChild.ChildNodes; foreach (XmlNode aN in nodeList2)
{
XmlElement axe = (XmlElement)aN;
string biaoqian = axe.Name;
string value = axe.InnerXml; }
#endregion #region 二:新XML文档的建立与节点操作(对data.xml操作)
XmlDocument xmldoc = new XmlDocument();
//加入XML的声明段落,<?xml version="1.0" encoding="gb2312"?>
XmlDeclaration xmldecl;
xmldecl = xmldoc.CreateXmlDeclaration("1.0", "utf-8", null);
xmldoc.AppendChild(xmldecl); //加入一个根元素
XmlElement xmlelem = xmldoc.CreateElement("", "User", "");
xmldoc.AppendChild(xmlelem);
//加入另外一个元素 XmlNode root = xmldoc.SelectSingleNode("User");//查找<User>
XmlElement xe1 = xmldoc.CreateElement("Persion");//创建一个<Node>节点
xe1.SetAttribute("id", "");//设置该节点id属性 root.AppendChild(xe1);//将persion添加到<User>节点中 XmlElement xesub1 = xmldoc.CreateElement("name");
xesub1.InnerText = "李鹏";//设置文本节点
xe1.AppendChild(xesub1);//添加到<Node>节点中
XmlElement xesub2 = xmldoc.CreateElement("gender");
xesub2.InnerText = "男";
xe1.AppendChild(xesub2);
XmlElement xesub3 = xmldoc.CreateElement("age");
xesub3.InnerText = "";
xe1.AppendChild(xesub3); //保存创建好的XML文档
xmldoc.Save(Server.MapPath("~/file/data.xml")); #endregion #region 三:修改节点的值和删除一个节点(对userinfo.xml操作)
XmlNodeList NDs = xml.SelectNodes("/UserInfo/Persion");
foreach (XmlNode axn in NDs)
{ XmlElement axe = (XmlElement)axn;
string str = axe.GetAttribute("id");
if (str == "")
{
XmlElement axelm = xml.CreateElement("age");
axelm.InnerXml = ""; axn.AppendChild(axelm);
}
if (str == "")
{
//必须要用父节点移除子节点
node.RemoveChild(axe);
}
}
xml.Save(Server.MapPath("~/file/userinfo.xml"));
#endregion }
}
}

结果:

<UserInfo>
<Persion id="001">
<name>李鹏</name>
<gender>男</gender>
</Persion>
<Persion id="002">
<name>小明</name>
<gender>男</gender>
<age>20</age>
</Persion>
</UserInfo>

XML相关操作的更多相关文章

  1. VS2012 Unit Test —— 我对IdleTest库动的大手术以及对Xml相关操作进行测试的方式

    [1]我的IdleTest源码地址:http://idletest.codeplex.com/ [2]IdleTest改动说明:2013年10月份在保持原有功能的情况下对其动了较大的手术,首先将基本的 ...

  2. C# XML相关操作

    XML是一种意见单文本格式存储数据的方式,这意味着它可以被任何计算机读取.XML中完整的数据集就是XML文档. 在名称空间System.Xml下面大部分类型都是用来支持DOM处理模型的.其中很多类型配 ...

  3. sql server中对xml进行操作

    一.前言 SQL Server 2005 引入了一种称为 XML 的本机数据类型.用户可以创建这样的表,它在关系列之外还有一个或多个 XML 类型的列:此外,还允许带有变量和参数.为了更好地支持 XM ...

  4. XML相关知识全接触(一)

    XML文件格式已经出来很久了.他的风头如今在JSON.YAML等新兴文件格式的冲击下已经显的不那么强劲.但是XML仍然是当今世界上使用最广泛的文件格式.围绕着它也有一大堆的概念和知识点.所以我们还是很 ...

  5. JqGrid相关操作

    JqGrid相关操作 根据jqGrid的文档,要想生成一个jqGrid,最直接的方法就是:$("#grid_id").jqGrid(options);也就是通过选择符得到一个tab ...

  6. 利用JAVA API远程进行HDFS的相关操作

    学习HDFS有一段时间了,现在把自己总结的HDFS的相关操作代码展示给大家. 主要有HDFS的增删改查,文件的追加,windows本地文件的上传,hdfs文件的下载,文件重命名,创建目录,文件是否存在 ...

  7. XML相关知识

    XML的定义:  XML即可扩展标记语言标记是指计算机所能理解的信息符号,通过此种标记,计算机之间可以处理包含各种信息的文章等.如何定义这些标记,既可以选择国际通用的标记语言,比如HTML,也可以使用 ...

  8. DateTimeHelper【日期类型与字符串互转以及日期对比相关操作】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 实现日期和字符串之间的转换以及日期的相关操作: 1.日期格式的字符串输出为Date类型: 2.将Date类型以指定格式输出: 3.将 ...

  9. 关于C#资源文件的相关操作

    关于资源文件的相关操作. //1.比较常见的有获取资源文件对应的文件流,然后转换到相对应的文件 //比较典型的做法是通过代码程序集加载指定资源 //如下通过Assembly的静态方法GetExecut ...

随机推荐

  1. iptables使用

    iptables规则的查看.添加.删除和修改 1.查看 iptables -nvL --line-number (这个命令跟/etc/init.d/iptables status 输出差不多) -L ...

  2. NSDateFormatter

    NSDate *now = [NSDate date]; NSDateFormatter *fmt = [[NSDateFormatter alloc] init]; fmt.dateFormat = ...

  3. C++Primer 第五章

    //1.表达式语句的作用:执行表达式并丢弃求值结果 ; value + ; //执行,并丢弃结果 //2.复合语句是指用花括号括起来的语句和声明的序列,复合语句称为块.一个块就是一个作用域.块不以分号 ...

  4. "数学口袋精灵"bug的发现及单元测试

    1.项目内容: 团队项目:二次开发 至此,我们有了初步的与人合作经验,接下来投入到更大的团队中去. 也具备了一定的个人能力,能将自己的代码进行测试.接下来尝试在别人已有的基础上进行开发. 上一界51冯 ...

  5. 卸载了mysql之后,mysql服务仍在,显示读取描述失败,错误代码2

    卸载了mysql之后,mysql服务仍在,显示读取描述失败,错误代码2 用360软件管家,卸载mysql5.5,卸载了mysql之后,再依次删除 mysql的安装目录.c盘下的隐藏文件夹Program ...

  6. Android 利用Service实现下载网络图片至sdk卡

    package com.example.myapp5; import android.app.Activity; import android.content.Intent; import andro ...

  7. 夺命雷公狗---linux之centos的安装

    由于要玩node.js了,所以还是来复习下linux系统才行,所以夺命雷公狗分享两套安装linux的方法,这是centos的安装方法,,, 管理员默认帐号为:root,密码则是刚才您输入的那个...

  8. 使用java访问 动态链接库(dll)

    在这个时候,我们可以使用的java技术有jni.jna.jnative,这个大部分都可以完成任务.但是有时候我们在实际情况中拿到的dll有变化,当我们需要用的函数是在dll中的类里面的话,我们再使用前 ...

  9. SQL——存储过程

    1. 为什么使用存储过程 应用程序通过T-SQL语句到服务器的过程是不安全的. 1) 数据不安全 2)每次提交SQL代码都要经过语法编译后在执行,影响应用程序的运行性能 3) 网络流量大 2. 什么是 ...

  10. 项目中empty遇到的一个问题

    搜索传参时,数据能获取到,搜索结果不是根据参数得出的,在定义搜索条件时因为empty引起的一个问题,键为0的值没有获取到, 记住:!empty 已经把0排除了