在.net开发中经常需要读写xml形式的文件(app.config和web.config分别是WinForm和WebForm中使用到的 xml文件的一个特列,并且微软提供了通用的方法,在此就不赘述了), .net类库提供了多种读写xml文件的方式,每一种方式都有其优点和 缺点,因而有其实用性。
下面列出微软.net类库提供的读写xml文件个类及其特点:
类名称 优点 缺点
XmlReader 快速、高效、可扩展 只读,只向前,需要人工验证
XmlDocument 可往返、可读写、支持XPath筛选 比XmlReader慢
XPathNavigator 可往返,支持XPath和XSLT 只读
XPathDocument 比XmlDocument,优化支持XPath和XSLT 比XmlReader慢
本文提到的XmlReader也是微软类库中的一个类,它的特点是快速高效,并且可扩展,缺点是只读。
下面举例说明XmlReader的用法:
(一)用到的xml文件:meu.xml

<?xml version="1.0" encoding="utf-8" ?>
<Menus>
<Menu title="常用网址">
<item name="天下网" url="http://www.netskycn.com" id=""/>
<item name="天下网生活论坛" url="http://life.netskycn.com" id=""/>
<item name="csdn" url="http://www.csdn.net" id=""/>
<item name="我的博客" url="http://blog.csdn.net/zhoufoxcn" id=""/>
<item name="百度" url="http://www.baidu.com" id=""/>
<item name="Google" url="http://www.google.cn" id=""/>
<item name="微软" url="http://www.microsoft.com" id=""/>
</Menu>
<Menu title="娱乐网址">
<item name="奇虎" url="http://www.qihoo.com" id=""/>
<item name="网易" url="http://www.163.com" id=""/>
<item name="天涯" url="http://www.tianya.cn" id=""/>
</Menu>
<Menu title="安全网址">
<item name="" url="http://www.safe360.com" id=""/>
<item name="瑞星" url="http://www.rising.com.cn" id=""/>
</Menu>
</Menus>

(二)读取并显示:ReadXml.aspx

<%@ Page Language="C#" ContentType="text/html" ResponseEncoding="gb2312" %>
<%@ Import Namespace="System.Xml" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>XMLReader实例</title>
</head>
<body>
<script runat="server">
//首发地址:http://blog.csdn.net/zhoufoxcn/archive/2007/12/23/1961624.aspx
protected void Page_Load(Object Src, EventArgs E)
{
if (!IsPostBack)
{
XmlReader xmlReader = XmlReader.Create(Server.MapPath("Menu.xml"));
while (xmlReader.Read())
{
Response.Write("<li>节点类型:" + xmlReader.NodeType + "==<br>");
switch (xmlReader.NodeType)
{
case XmlNodeType.XmlDeclaration:
for (int i = ; i < xmlReader.AttributeCount; i++)
{
xmlReader.MoveToAttribute(i);
Response.Write("属性:" + xmlReader.Name + "=" + xmlReader.Value+"&nbsp;");
}
break;
case XmlNodeType.Attribute:
for (int i = ; i < xmlReader.AttributeCount; i++)
{
xmlReader.MoveToAttribute(i);
Response.Write("属性:" + xmlReader.Name + "=" + xmlReader.Value+"&nbsp;");
}
break;
case XmlNodeType.CDATA:
Response.Write("CDATA:" + xmlReader.Value+"&nbsp;");
break;
case XmlNodeType.Element:
Response.Write("节点名称:" + xmlReader.LocalName+"<br>");
for (int i = ; i < xmlReader.AttributeCount; i++)
{
xmlReader.MoveToAttribute(i);
Response.Write("属性:" + xmlReader.Name + "=" + xmlReader.Value+"&nbsp;");
}
break;
case XmlNodeType.Comment:
Response.Write("Comment:" + xmlReader.Value);
break;
case XmlNodeType.Whitespace:
Response.Write("Whitespace:" + "&nbsp;");
break;
case XmlNodeType.ProcessingInstruction:
Response.Write("ProcessingInstruction:" + xmlReader.Value);
break;
case XmlNodeType.Text:
Response.Write("Text:" + xmlReader.Value);
break;
}
}
xmlReader.Close();
}
}
</script>
</body>
</html>
特别说明的是:menu.xml和ReadXml.aspx文件放在同一个文件夹下,如果实际情况与此不符,请根据实际情况更改。
以下是输出结果:
  • 节点类型:XmlDeclaration==
    属性:version=1.0 属性:encoding=utf-8
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:Menus
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:Menu
    属性:title=常用网址
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=天下网 属性:url=http://www.netskycn.com 属性:id=1
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=天下网生活论坛 属性:url=http://life.netskycn.com 属性:id=2
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=csdn 属性:url=http://www.csdn.net 属性:id=3
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=我的博客 属性:url=http://blog.csdn.net/zhoufoxcn 属性:id=4
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=百度 属性:url=http://www.baidu.com 属性:id=5
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=Google 属性:url=http://www.google.cn 属性:id=6
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=微软 属性:url=http://www.microsoft.com 属性:id=7
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:EndElement==
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:Menu
    属性:title=娱乐网址
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=奇虎 属性:url=http://www.qihoo.com 属性:id=12
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=网易 属性:url=http://www.163.com 属性:id=13
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=天涯 属性:url=http://www.tianya.cn 属性:id=14
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:EndElement==
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:Menu
    属性:title=安全网址
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=360 属性:url=http://www.safe360.com 属性:id=15
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=瑞星 属性:url=http://www.rising.com.cn 属性:id=16
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:EndElement==
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:EndElement==

使用XmlReader读取xml文件之二的更多相关文章

  1. 【C#-读取XML文件】XMLReader读取XML文档

    使用   XmlReader.Create("文件路径")   加载xml文件 XmlReader使用流的方式来读取. //使用XMLReader读取XML数据 XmlReader ...

  2. C#读取XML文件的基类实现

    刚到新单位,学习他们的源代码,代码里读写系统配置文件的XML代码比较老套,直接写在一个系统配置类里,没有进行类的拆分,造成类很庞大,同时,操作XML的读写操作都是使用SetAttribute和node ...

  3. C#读取XML文件的方法

    先写一个xml文件: <?xml version="1.0" encoding="utf-8" ?> <bookste> <!-- ...

  4. 在C#中创建和读取XML文件

    1.创建简单的XML文件 为了便于测试,我们首先创建控制台应用程序,项目命名为CreateXml,Program.cs代码如下: 这样会在C盘根目录下创建data2.xml文件,文件内容为 using ...

  5. Java获取路径方法&相对路径读取xml文件方法

    (1).request.getRealPath("/");//不推荐使用获取工程的根路径 (2).request.getRealPath(request.getRequestURI ...

  6. python读取xml文件

    关于python读取xml文章很多,但大多文章都是贴一个xml文件,然后再贴个处理文件的代码.这样并不利于初学者的学习,希望这篇文章可以更通俗易懂的教如何使用python 来读取xml 文件. 什么是 ...

  7. 读取xml文件转成List<T>对象的两种方法(附源码)

    读取xml文件转成List<T>对象的两种方法(附源码) 读取xml文件,是项目中经常要用到的,所以就总结一下,最近项目中用到的读取xml文件并且转成List<T>对象的方法, ...

  8. C#中经常使用的几种读取XML文件的方法

    XML文件是一种经常使用的文件格式,比如WinForm里面的app.config以及Web程序中的web.config文件,还有很多重要的场所都有它的身影.Xml是Internet环境中跨平台的,依赖 ...

  9. python专题-读取xml文件

    关于python读取xml文章很多,但大多文章都是贴一个xml文件,然后再贴个处理文件的代码.这样并不利于初学者的学习,希望这篇文章可以更通俗易懂的教如何使用python 来读取xml 文件. 什么是 ...

随机推荐

  1. Octet string 解析

    百度百科的 ASN.1 http://baike.baidu.com/view/26378.htm 什么是 octet string 结构化字节 怎么解析,这里有微软的解析方法 If the byte ...

  2. USACO 1.3... 虫洞 解题报告(搜索+强大剪枝+模拟)

    这题可真是又让我找到了八数码的感觉...哈哈. 首先,第一次见题,没有思路,第二次看题,感觉是搜索,就这样写下来了. 这题我几乎是一个点一个点改对的(至于为什么是这样,后面给你看一个神奇的东西),让我 ...

  3. 小项目--反eclass

    前言—— 最近会把前一段时间闲的无聊写的一些很小的项目写一些博客,用来练练手. 引子—— 最近班里有个很讨厌的软件,,,,教育局规定每个学校要上传多媒体使用记录,所以学校就给班里每台电脑上装了一个比较 ...

  4. phonegap安卓环境下使用BarcodeScanner插件扫描二维码教程

    由于一直在使用phoneGap来开发安卓应用,而对于原生Java小白的我最近这几天一直陷入了如何使用phonegap的BarcodeScanner插件这件事情上,可以说查遍了百度和Google,虽然只 ...

  5. YUV422 YUV420 Planar \ Semi-Planar \ Interleaved

    关于yuv 格式 YUV 格式通常有两大类:打包(packed)格式和平面(planar)格式.前者将 YUV 分量存放在同一个数组中,通常是几个相邻的像素组成一个宏像素(macro-pixel);而 ...

  6. 学php之翻译wordpress(2)

    wp-load.php <?php /** * Bootstrap file for setting the ABSPATH constant * and loading the wp-conf ...

  7. 踩坑学php(1)

    前言: 为什么要学php 呢?作为一个前端,一直有着了解后台的好奇心:作为一个计算机毕业的,一直有着实践更多设计模式和数据库相关的东西:而php 非常流行,拥有非常多的资源,入门应该容易: 为什么叫& ...

  8. ecshop简单结构

    Ecshop包括的文件夹有admin.api.cert.data.images.includes.js. languages.plugins.temp.theme.wap.widget这些文件夹,和根 ...

  9. 自动生成XML空节点格式的差异

    我们用C#开发了上位机配置软件,用C开发了嵌入式软件,然后他们之间的参数交互靠XML文件来沟通. C#中添加一个空的节点有以下几种情况. 不给节点的InnerText赋值: <root> ...

  10. SQL Server数据库空间管理 (1)

    数据库经常遇到的问题: 1).数据库文件空间用尽  2).日志文件不停增长 3).数据库文件无法收缩  4).自动增长和自动收缩 本系列就以上面的4个问题入手分析并总结数据库空间的管理方法.   1. ...