下面列出微软.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="1"/> <item name="天下网生活论坛" url="http://l if e.netskycn.com" id="2"/> <item name="csdn" url="http://www.csdn.net" id="3"/> <item name="我的博客" url="http://blog.csdn.net/zhoufoxcn" id="4"/> <item name="百度" url="http://www.baidu.com" id="5"/> <item name="Google" url="http://www.google.cn" id="6"/> <item name="微软" url="http://www.microsoft.com" id="7"/> </Menu> <Menu title="文娱网址"> <item name="奇虎" url="http://www.qihoo.com" id="12"/> <item name="网易" url="http://www.163.com" id="13"/> <item name="天涯" url="http://www.tianya.cn" id="14"/> </Menu> <Menu title=" 平安 网址"> <item name="360" url="http://www.safe360.com" id="15"/> <item name="瑞星" url="http://www.rising.com.cn" id="16"/> </Menu> </Menus>
(二)读取并显现:ReadXml.aspx
<?xml version="1.0" encoding="utf-8" ?> <Menus> <Menu title="经常运用网址"> <item name="天下网" url="http://www.netskycn.com" id="1"/> <item name="天下网生活论坛" url="http://life.netskycn.com" id="2"/> <item name="csdn" url="http://www.csdn.net" id="3"/> <item name="我的博客" url="http://blog.csdn.net/zhoufoxcn" id="4"/> <item name="百度" url="http://www.baidu.com" id="5"/> <item name="Google" url="http://www.google.cn" id="6"/> <item name="微软" url="http://www.microsoft.com" id="7"/> </Menu> <Menu title="文娱网址"> <item name="奇虎" url="http://www.qihoo.com" id="12"/> <item name="网易" url="http://www.163.com" id="13"/> <item name="天涯" url="http://www.tianya.cn" id="14"/> </Menu> <Menu title="平安网址"> <item name="360" url="http://www.safe360.com" id="15"/> <item name="瑞星" url="http://www.rising.com.cn" id="16"/> </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"> 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 = 0; i < xmlReader.AttributeCount; i++) { xmlReader.MoveToAttribute(i); Response.Write("属性:" + xmlReader.Name + "=" + xmlReader.Value+" "); } break; case XmlNodeType.Attribute: for (int i = 0; i < xmlReader.AttributeCount; i++) { xmlReader.MoveToAttribute(i); Response.Write("属性:" + xmlReader.Name + "=" + xmlReader.Value+" "); } break; case XmlNodeType.CDATA: Response.Write("CDATA:" + xmlReader.Value+" "); break; case XmlNodeType.Element: Response.Write("节点称号:" + xmlReader.LocalName+"<br>"); for (int i = 0; i < xmlReader.AttributeCount; i++) { xmlReader.MoveToAttribute(i); Response.Write("属性:" + xmlReader.Name + "=" + xmlReader.Value+" "); } break; case XmlNodeType.Comment: Response.Write("Comment:" + xmlReader.Value); break; case XmlNodeType.Whitespace: Response.Write("Whitespace:" + " "); 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文件的代码案例的细致内容,更多请关注ki4网别的相干文章!