XmlReader用于读取Xml文件,XmlWriter用于将数据写到Xml文件。其实,在印象当中,XML很多的操作类都支持直接Save、Read也支持接受XmlReader与XmlWriter类的示例作为参数,但是为什么还要有这个两类来专门用于读写XML文件呢?因为它们有强大的自定义格式功能;
一、XmlReader的使用
XmlReader类专门用于读取Xml文件,最大的特点在于支持Settings。
属性 | 说明 |
AttributeCount | 当在派生类中被重写时,获取当前节点上的属性数 |
BaseURI | 当在派生类中被重写时,获取当前节点的基 URI |
CanReadBinaryContent | 获取一个值,该值指示 XmlReader 是否实现二进制内容读取方法 |
Depth | 获取 XML 文档中当前节点的深度 |
EOF | 获取一个值,该值指示此读取器是否定位在流的结尾 |
HasAttributes | 获取一个值,该值指示当前节点是否有任何属性 |
HasValue | 获取一个值,该值指示当前节点是否可以具有 Value |
IsDefault | 获取一个值,该值指示当前节点是否是从 DTD 或架构中定义的默认值生成的特性 |
IsEmptyElement | 获取一个值,该值指示当前节点是否为空元素(例如 <MyElement/>) |
Item | 获取具有指定索引的属性的值,支持整形,字符串,LocalName 和 NamespaceURI作为参数 |
LocalName | 获取当前节点的本地名称 |
Name | 获取当前节点的限定名 |
NamespaceURI | 获取读取器定位在其上的节点的命名空间 URI |
NameTable | 获取与该实现关联的 XmlNameTable |
NodeType | 获取当前节点的类型 |
Prefix | 获取与当前节点关联的命名空间前缀 |
QuoteChar | 获取用于括住特性节点值的引号字符 |
ReadState | 获取读取器的状态 |
SchemaInfo | 获取作为架构验证结果分配给当前节点的架构信息 |
Settings | 获取用于创建此 XmlReader 实例的 XmlReaderSettings 对象 |
Value | 获取当前节点的文本值 |
ValueType | 获取当前节点的公共语言运行时 (CLR) 类型 |
XmlLang | 获取当前的 xml:lang 范围 |
XmlSpace | 获取当前的 xml:space 范围 |
常用方法:
方法 | 说明 |
Close | 将 ReadState 更改为 Closed |
Create | 使用指定的参数类型创建一个新的 XmlReader 实例 |
Dispose | 释放由 XmlReader 类的当前实例占用的所有资源 |
GetAttribute | 当在派生类中被重写时,获取具有指定索引的属性的值 |
GetValueAsync | 异步获取当前节点的值 |
IsName | 返回一个值,该值指示字符串参数是否是有效的 XML 名称 |
IsNameToken | 返回一个值,该值指示该字符串参数是否是有效的 XML 名称标记 |
IsStartElement | 调用 MoveToContent 并测试当前内容节点是否是开始标记或空元素标记 |
LookupNamespace | 在当前元素的范围内解析命名空间前缀 |
MoveToAttribute | 移动到具有指定索引的属性 |
MoveToContent | 如果此节点不是内容节点,则读取器向前跳至下一个内容节点或文件结尾。 |
MoveToElement | 移动到包含当前属性节点的元素 |
MoveToFirstAttribute | 移动到第一个属性 |
MoveToNextAttribute | 移动到下一个属性 |
Read | 从流中读取下一个节点 |
ReadAttributeValue | 将属性值解析为一个或多个 Text、EntityReference 或 EndEntity 节点 |
ReadContentAs | 将内容作为指定类型的对象读取 |
ReadStartElement | 检查当前节点是否为元素并将读取器推进到下一个节点 |
ReadElementContentAs | 将元素内容作为请求类型读取 |
ReadElementString | 读取纯文本元素 |
ReadEndElement | 检查当前内容节点是否为结束标记并将读取器推进到下一个节点 |
ReadInnerXml | 将所有内容(包括标记)当做字符串读取 |
ReadOuterXml | 读取表示该节点和所有它的子级的内容(包括标记) |
ReadString | 将元素或文本节点的内容当做字符串读取 |
ReadSubtree | 此实例可用于读取当前节点及其所有子节点 |
ReadToDescendant | 让 XmlReader 前进到下一个具有指定限定名的子代元素 |
ReadToFollowing | 一直读取,直到找到具有指定限定名的元素 |
ReadToNextSibling | 让 XmlReader 前进到下一个具有指定限定名的同级元素 |
ReadValueChunk | 读取嵌入在 XML 文档中的大量文本流 |
ResolveEntity | 解析 EntityReference 节点的实体引用 |
Skip | 跳过当前节点的子级 |
示例:
class Program
{
static void Main(string[] args)
{
//<?xml version="1.0" encoding="utf-8"?>
//<Persons>
// <Person>
// <Name>刘备</Name>
// <Age>28</Age>
// </Person>
//</Persons>
XmlReader reader = XmlReader.Create(@"D:\123.xml");
reader.ReadString();
while (reader.Read())
{
if (reader.NodeType == XmlNodeType.Element)
{
if (reader.Name == "Name")
{
Console.WriteLine(reader.ReadElementString()); //刘备
Console.WriteLine(reader.HasAttributes); //false
}
}
}
Console.ReadKey();
}
}
知识兔大多数方法和属性的使用方法都和上面的例子相似,不在啰嗦。下面来说说,XmlReader的特色功能,自定义格式,其中最主要用到的是属性Settings。
示例2:
static void Main(string[] args)
{
//<?xml version="1.0" encoding="utf-8"?>
//<Persons>
// <Person>
// <!-- 这是一个牛人 -->
// <Name>刘备</Name>
// <Age>28</Age>
// </Person>
//</Persons>
XmlReaderSettings RSetting = new XmlReaderSettings();
RSetting.IgnoreComments = false; //如果设置为true则忽略所有注释
XmlReader reader = XmlReader.Create(@"D:\123.xml", RSetting);
reader.ReadString();
while (reader.Read())
{
if (reader.NodeType == XmlNodeType.Comment)
{
Console.WriteLine(reader.Value); //这是一个牛人
}
}
Console.ReadKey();
}
}
知识兔