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#】的更多相关文章

  1. Android 解析XML文件和生成XML文件

    解析XML文件 public static void initXML(Context context) { //can't create in /data/media/0 because permis ...

  2. Android之解析XML

    1.XML:可扩展标记语言. 可扩展标记语言是一种很像超文本标记语言的标记语言. 它的设计宗旨是传输数据,而不是显示数据. 它的标记没有被预定义.需要自行定义标签. 它被设计为具有自我描述性. 是W3 ...

  3. Android之Pull解析XML

    一.Pull解析方法介绍 除了可以使用SAX和DOM解析XML文件,也可以使用Android内置的Pull解析器解析XML文件.Pull解析器的运行方式与SAX解析器相似.它也是事件触发的.Pull解 ...

  4. Android之DOM解析XML

    一.DOM解析方法介绍 DOM是基于树形结构的节点或信息片段的集合,允许开发人员使用DOM API遍历XML树,检索所需数据.分析该结构通常需要加载整个文档和构造树形结构,然后才可以检索和更新节点信息 ...

  5. Android之SAX解析XML

    一.SAX解析方法介绍 SAX(Simple API for XML)是一个解析速度快并且占用内存少的XML解析器,非常适合用于Android等移动设备. SAX解析器是一种基于事件的解析器,事件驱动 ...

  6. Android 使用pull,sax解析xml

    pull解析xml文件 1.获得XmlpullParser类的引用 这里有两种方法 //解析器工厂 XmlPullParserFactory factory=XmlPullParserFactory. ...

  7. 用 ElementTree 在 Python 中解析 XML

    用 ElementTree 在 Python 中解析 XML 原文: http://eli.thegreenplace.net/2012/03/15/processing-xml-in-python- ...

  8. java解析xml的三种方法

    java解析XML的三种方法 1.SAX事件解析 package com.wzh.sax; import org.xml.sax.Attributes; import org.xml.sax.SAXE ...

  9. WP8解析XML格式文件

    DOTA2 WebAPI请求返回的格式有两种,一种是XML,一种是JSON,默认是返回JSON格式,如果要返回XML格式的话,需要在加上format=xml. 这里举一个简单的解析XML格式的例子(更 ...

  10. JAVA使用SAX解析XML文件

    在我的另一篇文章(http://www.cnblogs.com/anivia/p/5849712.html)中,通过一个例子介绍了使用DOM来解析XML文件,那么本篇文章通过相同的XML文件介绍如何使 ...

随机推荐

  1. 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 ...

  2. build.gradle中引入jar

    只需在 dependencies{}中添加: compile fileTree(include: ['*.jar'], dir: 'libs')

  3. PKU 1050-To The Max(找矩形内元素最大和)

    Given a two-dimensional array of positive and negative integers, a sub-rectangle is any contiguous s ...

  4. 哈希表原理及hashmap简单实现

    哈希表也叫做散列表.在各种语言中都有hashmap的实现.其最突出的优点是查找和插入以及删除具有常数的时间复杂度 我们可以把哈希表理解为数组+链表 数组具有常数复杂度的查找,为什么呢,因为数组是在内存 ...

  5. wxPython Major类

    转载自:http://www.yiibai.com/wxpython/wxpython_major_classes.html   原始的 wxWidgets(用C++编写)是一个巨大的类库.GUI类从 ...

  6. [LeetCode] Interleaving String [30]

    题目 Given s1, s2, s3, find whether s3 is formed by the interleaving of s1 and s2. For example, Given: ...

  7. 关于 jsp:include 传参的用法

    引用模版页面的代码,如下: <jsp:include page="/WEB-INF/template/nav_template.jsp">     <jsp:pa ...

  8. [扩展KMP][HDU3613][Best Reward]

    题意: 将一段字符串 分割成两个串 如果分割后的串为回文串,则该串的价值为所有字符的权值之和(字符的权值可能为负数),否则为0. 问如何分割,使得两个串权值之和最大 思路: 首先了解扩展kmp 扩展K ...

  9. 【二分图最大匹配】【HDU2063】过山车

    [科普]什么是BestCoder?如何参加? 过山车 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Ja ...

  10. C# 多线程的坑 之 代码变序

    英文好的,可跳过,直接打开底部的“参考“链接. 代码变序--reordering of memory operations 大概4年前,阅读了这篇文章后http://www.albahari.com/ ...