XML相关操作
一、简单介绍
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相关操作的更多相关文章
- VS2012 Unit Test —— 我对IdleTest库动的大手术以及对Xml相关操作进行测试的方式
[1]我的IdleTest源码地址:http://idletest.codeplex.com/ [2]IdleTest改动说明:2013年10月份在保持原有功能的情况下对其动了较大的手术,首先将基本的 ...
- C# XML相关操作
XML是一种意见单文本格式存储数据的方式,这意味着它可以被任何计算机读取.XML中完整的数据集就是XML文档. 在名称空间System.Xml下面大部分类型都是用来支持DOM处理模型的.其中很多类型配 ...
- sql server中对xml进行操作
一.前言 SQL Server 2005 引入了一种称为 XML 的本机数据类型.用户可以创建这样的表,它在关系列之外还有一个或多个 XML 类型的列:此外,还允许带有变量和参数.为了更好地支持 XM ...
- XML相关知识全接触(一)
XML文件格式已经出来很久了.他的风头如今在JSON.YAML等新兴文件格式的冲击下已经显的不那么强劲.但是XML仍然是当今世界上使用最广泛的文件格式.围绕着它也有一大堆的概念和知识点.所以我们还是很 ...
- JqGrid相关操作
JqGrid相关操作 根据jqGrid的文档,要想生成一个jqGrid,最直接的方法就是:$("#grid_id").jqGrid(options);也就是通过选择符得到一个tab ...
- 利用JAVA API远程进行HDFS的相关操作
学习HDFS有一段时间了,现在把自己总结的HDFS的相关操作代码展示给大家. 主要有HDFS的增删改查,文件的追加,windows本地文件的上传,hdfs文件的下载,文件重命名,创建目录,文件是否存在 ...
- XML相关知识
XML的定义: XML即可扩展标记语言标记是指计算机所能理解的信息符号,通过此种标记,计算机之间可以处理包含各种信息的文章等.如何定义这些标记,既可以选择国际通用的标记语言,比如HTML,也可以使用 ...
- DateTimeHelper【日期类型与字符串互转以及日期对比相关操作】
版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 实现日期和字符串之间的转换以及日期的相关操作: 1.日期格式的字符串输出为Date类型: 2.将Date类型以指定格式输出: 3.将 ...
- 关于C#资源文件的相关操作
关于资源文件的相关操作. //1.比较常见的有获取资源文件对应的文件流,然后转换到相对应的文件 //比较典型的做法是通过代码程序集加载指定资源 //如下通过Assembly的静态方法GetExecut ...
随机推荐
- 不等高cell搭建(二)
一.commentView模块搭建 commentView样式分为两种 1.xib搭建界面 1.1 因为评论的样式大体上一样,我们可以用同一个xib来处理 1.2 最热评论 用 ...
- PostgreSQL Cascade Replication
PostgreSQL Cascade Replication node1:master:10.2.208.10:repclia(user) node2:upstreamnode:10.2.208.11 ...
- nyist 604 小明的难题
http://acm.nyist.net/JudgeOnline/problem.php?pid=604 小明的难题 时间限制:1000 ms | 内存限制:65535 KB 难度:1 描述 ...
- Java基础(60):Java打包生成Jar和Javadoc说明文档,以及在另外的工程中导入和使用自己的Jar
一.Jar包的导出 1.在Package Explorer中选中项目,右键,点击“Export” 2.在弹出框一次选择Java-->JAR file,点击Next 3.在新弹出的窗口选择 ...
- mysql之消息队列
消息队列:在消息的传输过程中保存消息的容器. 消息队列管理器在将消息从它的源中继到它的目标时充当中间人.队列的主要目的是提供路由并保证消息的传递:如果发送消息时接收者不可用,消息队列会保留消息,直到可 ...
- ViewPager相互嵌套,导致子ViewPager无法滑动,且子ViewPager中的view无法被点击
场景:当使用ViewPager进行嵌套的时候,子viewPager是无法进行嵌套的,因此我们要重写ViewPager类,并重写里层viewPager类中的onTouchEvent方法,调用其父 ...
- 夺命雷公狗---DEDECMS----7dedecms目录结构
我们dedecms的目录结构其实只需要一张图即可明了了,如下图所示:
- [fedora21]给fedora21安装fcitx输入法
如果已经安装了ibus,需要卸载ibus: sudo yum remove ibus; 安装fcitx: sudo yum install fcitx fcitx-pinyin fcitx-con ...
- $.trim()函数
$.trim(str) 返回:string: 参数str :String类型,需要去除两端空白字符的字符串.如果参数str不是字符串类型,该函数将自动将其转为字符串(一般调用其toString()方法 ...
- 【转】Web UI自动化测试原理
目前市面上有很多Web UI自动化测试框架,比如WatiN, Selinimu,WebDriver,还有VS2010中的Coded UI等等. 这些框架都可以操作Web中的控件,模拟用户输入,点击等 ...