解析XML【C#】
1.XML元素
XML元素包含一个开标记、元素中的数据、闭标记
例如:<book>book name</book>
其中book是元素名称 book name是元素数据
元素名称区分大小写
每一个XML文档中必须有一个根元素
2.XML属性
属性添加在元素的开标记内
<book titile = "book name"></book>或者<book title = 'book name'></book>
属性的值可以用双引号也可以用单引号
3.元素与属性举例
<book><title>book name</title></book>
<book title = "book name"></book>
上述两种没有本质的区别,但使用时建议使用第一种,因为可以对元素增加属性或子元素,但是不能这样操作属性。
4.XML读取解析
DOM解析XML文档:XML的文档结构是个树状结构
DOM的类在System.Xml中
XmlDocument:用于加载XML文件存放的磁盘位置
XmlNode:这个类表示文档书中的一个节点
XmlNodeList:表示一个节点的集合
XmlElement:表示XML文档中的一个元素
XmlAttribute:表示XML的一个属性
XmlText:表示开标记和闭标记之间的文本
(1)XmlDocument:加载xml文档
例:XmlDocument document = new XmlDocument();
document.load(@"D:\C#\books.xml");
(2)XmlElement:用于返回一个元素实例
XmlElement element = document.DocumentElement; //常用来返回一个根节点
XmlElement类包含许多方法和属性,可以处理树的节点和属性
1)FirstChild:返回根元素节点后的第一个子节点
2)LastChild:返回根元素节点后的最后一个子节点
3)ParentNode:返回当前元素的父节点
4)NextSibling:返回当前节点的父节点下的下一个节点
5)HasChildNodes:用来检查当前元素是否有子元素
(3)XmlText:表示开关标记之间的文本,是特殊的节点,属性有:
1)InnerText:获取当前节点范围内的所有子节点的文本连接起来的字符串
2)InnerXml:获取当前节点范围内的所有子节点的文本连接起来的字符串,包含标记
5.XML修改解析
(1)创建节点
创建节点方法:
1)CreateElement:用来创建XmlDocument类型的节点
2)CreateAttribute:用来创建XmlAttribute类型的节点
3)CreateTextNode:用来创建XmlTextNode类型的节点
4)CreateNode:用来创建任意类型的节点,包含上述三种以及其他
创建节点后添加操作:
1)AppendChild:把创建的节点类型追加到XmlNode类型或其他派生类型的节点后
2)InsertAfter:将新节点插入到特定的位置
3)InsertBefore:将新节点插入到特定位置
(2)删除节点
1)RemoveChild:删除当前节点范围内的一个指定的子节点
2)RemoveAll:删除该节点范围内的所有子节点
(3)修改节点
1)ReplaceChild:用新子节点替换旧子节点
6.XML查询解析
(1)使用XmlDocument 方法
XmlDocument document = new XmlDocument();
document.Load(filePath);
XmlNodeList list = document.GetElementsByTagName("book");
foreach (XmlNode node in list)
{
listBox1.Items.Add(node.Name);//listBox1类型是ListBox
}
(2)使用XPath选择特定的节点的方法
1)SelectSingleNode:用来选择一个节点,如果有多个,则返回第一个节点
2)SelectNodes:返回一个节点的集合,类型是XmlNodesList
选择特定的节点的方法参数XPath
XPath是XML文档的查询语言
using System;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.IO;
using System.Xml; namespace Update
{
public partial class Form1 : Form
{ string filePath = Directory.GetCurrentDirectory() + @"\uploadXML.xml";
public Form1()
{
InitializeComponent();
} //读取xml
private void button1_Click(object sender, EventArgs e)
{ if (File.Exists(filePath))
{ XmlDocument document = new XmlDocument();
document.Load(filePath);
XmlNode root = (XmlNode)document.DocumentElement;
//循环展示成树状
xmlProcess(root,); } } /*
* 循环展示成树状
*/
private void xmlProcess(XmlNode root,int i)
{ if (root == null)
{
return;
}
if (root is XmlElement)
{
listBox1.Items.Add(root.Name.PadLeft(root.Name.Length + i));
if (root.HasChildNodes)
{
xmlProcess(root.FirstChild,i+);
}
if (root.NextSibling != null)
{
xmlProcess(root.NextSibling, i);
} }
else if (root is XmlText)
{
string text = ((XmlText)root).Value;
listBox1.Items.Add(text.PadLeft(text.Length+i));
}
} //读取文本节点
private void button2_Click(object sender, EventArgs e)
{
XmlDocument document = new XmlDocument();
document.Load(filePath);
XmlNode root = (XmlNode)document.DocumentElement;
string values = root.InnerText;
string values2 = root.InnerXml;
string values3 = root.Value;
MessageBox.Show(values);
MessageBox.Show(values2);
MessageBox.Show(values3);
}
//添加节点
private void button3_Click(object sender, EventArgs e)
{
XmlDocument document = new XmlDocument();
document.Load(filePath);
XmlElement root = document.DocumentElement; //create node
XmlElement newBook = document.CreateElement("book");
XmlElement newTitle = document.CreateElement("title");
XmlElement newAuthor = document.CreateElement("author"); //create text
XmlText titleText = document.CreateTextNode("new title");
XmlText authorText = document.CreateTextNode("new author"); //insert
newTitle.AppendChild(titleText);
newAuthor.AppendChild(authorText); newBook.AppendChild(newTitle);
newBook.AppendChild(newAuthor); root.AppendChild(newBook); //save
document.Save(filePath); }
//删除节点
private void button4_Click(object sender, EventArgs e)
{
XmlDocument document = new XmlDocument();
document.Load(filePath);
XmlElement root = document.DocumentElement;
if (root.HasChildNodes)
{
XmlNode old = root.LastChild;
root.RemoveChild(old);
} document.Save(filePath); }
//修改节点
private void button5_Click(object sender, EventArgs e)
{
XmlDocument document = new XmlDocument();
document.Load(filePath);
XmlElement root = document.DocumentElement;
if (root.HasChildNodes)
{
XmlNode oldNode = root.LastChild;
XmlNode newNode = document.CreateElement("Book");
root.ReplaceChild(newNode, oldNode);
} document.Save(filePath); }
//查询节点
private void button6_Click(object sender, EventArgs e)
{
listBox1.Items.Clear(); XmlDocument document = new XmlDocument();
document.Load(filePath);
XmlNodeList list = document.GetElementsByTagName("book");//要查询的的节点名
foreach (XmlNode node in list)
{
listBox1.Items.Add(node.Name);
}
} }
}
原文:http://blog.csdn.net/itwit/article/details/6689313
解析XML【C#】的更多相关文章
- Android 解析XML文件和生成XML文件
解析XML文件 public static void initXML(Context context) { //can't create in /data/media/0 because permis ...
- Android之解析XML
1.XML:可扩展标记语言. 可扩展标记语言是一种很像超文本标记语言的标记语言. 它的设计宗旨是传输数据,而不是显示数据. 它的标记没有被预定义.需要自行定义标签. 它被设计为具有自我描述性. 是W3 ...
- Android之Pull解析XML
一.Pull解析方法介绍 除了可以使用SAX和DOM解析XML文件,也可以使用Android内置的Pull解析器解析XML文件.Pull解析器的运行方式与SAX解析器相似.它也是事件触发的.Pull解 ...
- Android之DOM解析XML
一.DOM解析方法介绍 DOM是基于树形结构的节点或信息片段的集合,允许开发人员使用DOM API遍历XML树,检索所需数据.分析该结构通常需要加载整个文档和构造树形结构,然后才可以检索和更新节点信息 ...
- Android之SAX解析XML
一.SAX解析方法介绍 SAX(Simple API for XML)是一个解析速度快并且占用内存少的XML解析器,非常适合用于Android等移动设备. SAX解析器是一种基于事件的解析器,事件驱动 ...
- Android 使用pull,sax解析xml
pull解析xml文件 1.获得XmlpullParser类的引用 这里有两种方法 //解析器工厂 XmlPullParserFactory factory=XmlPullParserFactory. ...
- 用 ElementTree 在 Python 中解析 XML
用 ElementTree 在 Python 中解析 XML 原文: http://eli.thegreenplace.net/2012/03/15/processing-xml-in-python- ...
- java解析xml的三种方法
java解析XML的三种方法 1.SAX事件解析 package com.wzh.sax; import org.xml.sax.Attributes; import org.xml.sax.SAXE ...
- WP8解析XML格式文件
DOTA2 WebAPI请求返回的格式有两种,一种是XML,一种是JSON,默认是返回JSON格式,如果要返回XML格式的话,需要在加上format=xml. 这里举一个简单的解析XML格式的例子(更 ...
- JAVA使用SAX解析XML文件
在我的另一篇文章(http://www.cnblogs.com/anivia/p/5849712.html)中,通过一个例子介绍了使用DOM来解析XML文件,那么本篇文章通过相同的XML文件介绍如何使 ...
随机推荐
- Node.js how to respond to an upgrade request?
You just need to call socket.write with the appropriate HTTP syntax as plain text along these lines ...
- build.gradle中引入jar
只需在 dependencies{}中添加: compile fileTree(include: ['*.jar'], dir: 'libs')
- PKU 1050-To The Max(找矩形内元素最大和)
Given a two-dimensional array of positive and negative integers, a sub-rectangle is any contiguous s ...
- 哈希表原理及hashmap简单实现
哈希表也叫做散列表.在各种语言中都有hashmap的实现.其最突出的优点是查找和插入以及删除具有常数的时间复杂度 我们可以把哈希表理解为数组+链表 数组具有常数复杂度的查找,为什么呢,因为数组是在内存 ...
- wxPython Major类
转载自:http://www.yiibai.com/wxpython/wxpython_major_classes.html 原始的 wxWidgets(用C++编写)是一个巨大的类库.GUI类从 ...
- [LeetCode] Interleaving String [30]
题目 Given s1, s2, s3, find whether s3 is formed by the interleaving of s1 and s2. For example, Given: ...
- 关于 jsp:include 传参的用法
引用模版页面的代码,如下: <jsp:include page="/WEB-INF/template/nav_template.jsp"> <jsp:pa ...
- [扩展KMP][HDU3613][Best Reward]
题意: 将一段字符串 分割成两个串 如果分割后的串为回文串,则该串的价值为所有字符的权值之和(字符的权值可能为负数),否则为0. 问如何分割,使得两个串权值之和最大 思路: 首先了解扩展kmp 扩展K ...
- 【二分图最大匹配】【HDU2063】过山车
[科普]什么是BestCoder?如何参加? 过山车 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- C# 多线程的坑 之 代码变序
英文好的,可跳过,直接打开底部的“参考“链接. 代码变序--reordering of memory operations 大概4年前,阅读了这篇文章后http://www.albahari.com/ ...