我的编程空间,编程开发者的网络收藏夹
学习永远不晚

C#如何使用XML

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

C#如何使用XML

本篇内容主要讲解“C#如何使用XML”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#如何使用XML”吧!

C#如何使用XML

对于XML,想必各位都比较了解,我也就不用费笔墨来描述它是什么了,我想在未来的Web开发中XML一定会大放异彩,XML是可扩展标记语言,使用它企业可以制定一套自己的数据格式,数据按照这种格式在网络中传输然后再通过XSLT将数据转换成用户期望的样子表示出来,这样便轻易的解决了数据格式不兼容的问题。用于Internet的数据传输,我想,这是XML对于我们这些程序员最诱人的地方!

我们今天的主题不是论述XML的好处,而是讨论在C#如何使用XML。下面我们来了解一下使用程序访问XML的一些基础理论知识。

访问的两种模型:

在程序中访问进而操作XML文件一般有两种模型,分别是使用DOM(文档对象模型)和流模型,使用DOM的好处在于它允许编辑和更新XML文档,可以随机访问文档中的数据,可以使用XPath查询,但是,DOM的缺点在于它需要一次性的加载整个文档到内存中,对于大型的文档,这会造成资源问题。流模型很好的解决了这个问题,因为它对XML文件的访问采用的是流的概念,也就是说,任何时候在内存中只有当前节点,但它也有它的不足,它是只读的,仅向前的,不能在文档中执行向后导航操作。虽然是各有千秋,但我们也可以在程序中两者并用实现优劣互补嘛,呵呵,这是题外话了!我们今天主要讨论XML的读取,那我们就详细讨论一下流模型吧!

流模型中的变体:

流模型每次迭代XML文档中的一个节点,适合于处理较大的文档,所耗内存空间小。流模型中有两种变体——“推”模型和“拉”模型。

推模型也就是常说的SAX,SAX是一种靠事件驱动的模型,也就是说:它每发现一个节点就用推模型引发一个事件,而我们必须编写这些事件的处理程序,这样的做法非常的不灵活,也很麻烦。

.NET中使用的是基于“拉”模型的实现方案,“拉”模型在遍历文档时会把感兴趣的文档部分从读取器中拉出,不需要引发事件,允许我们以编程的方式访问文档,这大大的提高了灵活性,在性能上“拉”模型可以选择性的处理节点,而SAX每发现一个节点都会通知客户机,从而,使用“拉”模型可以提高 Application的整体效率。

我们今天来讲一下该体系结构中的XmlTextReader类,该类提供对Xml文件进行读取的功能,它可以验证文档是否格式良好,如果不是格式良好的Xml文档,该类在读取过程中将会抛出XmlException异常,可使用该类提供的一些方法对文档节点进行读取,筛选等操作以及得到节点的名称和值,请牢记:XmlTextReader是基于流模型的实现,打个不恰当的比喻,XML文件就好象水源,闸一开水就流出,流过了就流过了不会也不可以往回流。内存中任何时候只有当前节点,你可以使用XmlTextReader类的Read()方法读取下一个节点。好了,说了这么多来看一个例子,编程要注重实际对吧。

Example1按纽遍历文档读取数据,Example2,Example3按纽得到节点类型,Example4过滤文档只获得数据内容,Example5得到属性节点,Example6按纽得到命名空间,Example7显示整个XML文档,为此,我专门写一个类来封装以上功能,该类代码如下:

  1. namespace XMLReading  

  2. {  

  3. using System;  

  4. using System.Xml;  

  5. using System.Windows.Forms;  

  6. using System.ComponentModel;  

  7.  

  8. /// <summary>  

  9. /// Xml文件读取器  

  10. /// </summary>  

  11.  

  12. public class XmlReader : IDisposable  

  13. {  

  14. private string _xmlPath;  

  15. private const string _errMsg = "Error Occurred While Reading ";  

  16. private ListBox _listBox;  

  17. private XmlTextReader xmlTxtRd;  

  18.  

  19. #region XmlReader 的构造器  

  20.  

  21. public XmlReader()  

  22. {  

  23. this._xmlPath = string.Empty;  

  24. this._listBox = null;  

  25. this.xmlTxtRd = null;  

  26. }  

  27.  

  28. /// <summary>  

  29. /// 构造器  

  30. /// </summary>  

  31. /// <param name="_xmlPath">xml文件绝对路径</param>  

  32. /// <param name="_listBox">列表框用于显示xml</param>  

  33.  

  34. public XmlReader(string _xmlPath, ListBox _listBox)  

  35. {  

  36. this._xmlPath = _xmlPath;  

  37. this._listBox = _listBox;  

  38. this.xmlTxtRd = null;  

  39. }  

  40.  

  41. #endregion  

  42. #region XmlReader 的资源释放方法  

  43.  

  44. /// <summary>  

  45. /// 清理该对象所有正在使用的资源  

  46.  

  47. /// </summary>  

  48.  

  49. public void Dispose()  

  50. {  

  51. this.Dispose(true);  

  52. GC.SuppressFinalize(this);  

  53. }  

  54.  

  55. /// <summary>  

  56. /// 释放该对象的实例变量  

  57. /// </summary>  

  58. /// <param name="disposing"></param>  

  59.  

  60. protected virtual void Dispose(bool disposing)  

  61. {  

  62. if (!disposing)  

  63. return;  

  64. if (this.xmlTxtRd != null)  

  65. {  

  66. this.xmlTxtRd.Close();  

  67. this.xmlTxtRd = null;  

  68. }  

  69.  

  70. if (this._xmlPath != null)  

  71. {  

  72. this._xmlPath = null;  

  73. }  

  74. }  

  75.  

  76. #endregion  

  77. #region XmlReader 的属性  

  78.  

  79. /// <summary>  

  80. /// 获取或设置列表框用于显示xml  

  81. /// </summary>  

  82.  

  83. public ListBox listBox  

  84. {  

  85. get  

  86. {  

  87. return this._listBox;  

  88. }  

  89. set  

  90. {  

  91. this._listBox = value;  

  92. }  

  93. }  

  94.  

  95. /// <summary>  

  96. /// 获取或设置xml文件的绝对路径  

  97. /// </summary>  

  98.  

  99. public string xmlPath  

  100. {  

  101. get  

  102. {  

  103. return this._xmlPath;  

  104. }  

  105. set  

  106. {  

  107. this._xmlPath = value;  

  108. }  

  109. }  

  110.  

  111. #endregion  

  112.  

  113. /// <summary>  

  114. /// 遍历Xml文件  

  115. /// </summary>  

  116.  

  117. public void EachXml()  

  118. {  

  119. this._listBox.Items.Clear();  

  120. this.xmlTxtRd = new XmlTextReader(this._xmlPath);  

  121.  

  122. try  

  123. {  

  124. while(xmlTxtRd.Read())  

  125. {  

  126. this._listBox.Items.Add(this.xmlTxtRd.Value);  

  127. }  

  128. }  

  129. catch(XmlException exp)  

  130. {  

  131. throw new XmlException(_errMsg + this._xmlPath + exp.ToString());  

  132. }  

  133. finally  

  134. {  

  135. if (this.xmlTxtRd != null)  

  136. this.xmlTxtRd.Close();  

  137. }  

  138. }  

  139.  

  140. /// <summary>  

  141. /// 读取Xml文件的节点类型  

  142. /// </summary>  

  143.  

  144. public void ReadXmlByNodeType()  

  145. {  

  146. this._listBox.Items.Clear();  

  147. this.xmlTxtRd = new XmlTextReader(this._xmlPath);  

  148.  

  149. try  

  150. {  

  151. while(xmlTxtRd.Read())  

  152. {  

  153. this._listBox.Items.Add(this.xmlTxtRd.NodeType.ToString());  

  154. }  

  155. }  

  156. catch(XmlException exp)  

  157. {  

  158. throw new XmlException(_errMsg + this._xmlPath + exp.ToString());  

  159. }  

  160. finally  

  161. {  

  162. if (this.xmlTxtRd != null)  

  163. this.xmlTxtRd.Close();  

  164. }  

  165. }  

  166.  

  167. /// <summary>  

  168. /// 根据节点类型过滤Xml文档  

  169. /// </summary>  

  170. /// <param name="xmlNType">XmlNodeType 节点类型的数组</param>  

  171.  

  172. public void FilterByNodeType(XmlNodeType[] xmlNType)  

  173. {  

  174. this._listBox.Items.Clear();  

  175. this.xmlTxtRd = new XmlTextReader(this._xmlPath);  

  176. try  

  177. {  

  178. while(xmlTxtRd.Read())  

  179. {  

  180. for (int i = 0; i < xmlNType.Length; i++)  

  181. {  

  182. if (xmlTxtRd.NodeType == xmlNType[i])  

  183. {  

  184. this._listBox.Items.Add(xmlTxtRd.Name + " 
    is Type " + xmlTxtRd.NodeType.ToString());  

  185. }  

  186. }  

  187. }  

  188. }  

  189. catch(XmlException exp)  

  190. {  

  191. throw new XmlException(_errMsg + this.xmlPath + exp.ToString());  

  192. }  

  193. finally  

  194. {  

  195. if (this.xmlTxtRd != null)  

  196. this.xmlTxtRd.Close();  

  197. }  

  198. }  

  199.  

  200. /// <summary>  

  201. /// 读取Xml文件的所有文本节点值  

  202.  

  203. /// </summary>  

  204.  

  205. public void ReadXmlTextValue()  

  206. {  

  207. this._listBox.Items.Clear();  

  208. this.xmlTxtRd = new XmlTextReader(this._xmlPath);  

  209.  

  210. try  

  211. {  

  212. while(xmlTxtRd.Read())  

  213. {  

  214. if (xmlTxtRd.NodeType == XmlNodeType.Text)  

  215. {  

  216. this._listBox.Items.Add(xmlTxtRd.Value);  

  217. }  

  218. }  

  219. }  

  220. catch(XmlException xmlExp)  

  221. {  

  222. throw new XmlException(_errMsg + this._xmlPath + xmlExp.ToString());  

  223. }  

  224. finally  

  225. {  

  226. if (this.xmlTxtRd != null)  

  227. this.xmlTxtRd.Close();  

  228. }  

  229. }  

  230.  

  231. /// <summary>  

  232. /// 读取Xml文件的属性  

  233. /// </summary>  

  234.  

  235. public void ReadXmlAttributes()  

  236. {  

  237. this._listBox.Items.Clear();  

  238. this.xmlTxtRd = new XmlTextReader(this._xmlPath);  

  239.  

  240. try  

  241. {  

  242. while(xmlTxtRd.Read())  

  243. {  

  244. if (xmlTxtRd.NodeType == XmlNodeType.Element)  

  245. {  

  246. if (xmlTxtRd.HasAttributes)  

  247. {  

  248. this._listBox.Items.Add("The Element " + xmlTxtRd.Name + " 
    has " + xmlTxtRd.AttributeCount + " Attributes");  

  249.  

  250. this._listBox.Items.Add("The Attributes are:");  

  251.  

  252. while(xmlTxtRd.MoveToNextAttribute())  

  253. {  

  254. this._listBox.Items.Add(xmlTxtRd.Name + " = " + xmlTxtRd.Value);  

  255. }  

  256. }  

  257. else  

  258. {  

  259. this._listBox.Items.Add("The Element " + xmlTxtRd.Name + " has no Attribute");  

  260. }  

  261. this._listBox.Items.Add("");  

  262. }  

  263. }  

  264. }  

  265. catch(XmlException xmlExp)  

  266. {  

  267. throw new XmlException(_errMsg + this._xmlPath + xmlExp.ToString());  

  268. }  

  269. finally  

  270. {  

  271. if (this.xmlTxtRd != null)  

  272. this.xmlTxtRd.Close();  

  273. }  

  274. }  

  275.  

  276. /// <summary>  

  277. /// 读取Xml文件的命名空间  

  278. /// </summary>  

  279.  

  280. public void ReadXmlNamespace()  

  281. {  

  282. this._listBox.Items.Clear();  

  283. this.xmlTxtRd = new XmlTextReader(this._xmlPath);  

  284. try  

  285. {  

  286. while(xmlTxtRd.Read())  

  287. {  

  288. if (xmlTxtRd.NodeType == XmlNodeType.Element && xmlTxtRd.Prefix != "")  

  289. {  

  290. this._listBox.Items.Add("The Prefix " + xmlTxtRd.Prefix + " 
    is associated with namespace " + xmlTxtRd.NamespaceURI);  

  291.  

  292. this._listBox.Items.Add("The Element with the local name " + xmlTxtRd.
    LocalName + " is associated with" + " the namespace " + xmlTxtRd.NamespaceURI);  

  293. }  

  294.  

  295. if (xmlTxtRd.NodeType == XmlNodeType.Element && xmlTxtRd.HasAttributes)  

  296. {  

  297. while(xmlTxtRd.MoveToNextAttribute())  

  298. {  

  299. if (xmlTxtRd.Prefix != "")  

  300. {  

  301. this._listBox.Items.Add("The Prefix " + xmlTxtRd.Prefix + 
    " is associated with namespace " + xmlTxtRd.NamespaceURI);  

  302.  

  303. this._listBox.Items.Add("The Attribute with the local name " + xmlTxtRd.
    LocalName + " is associated with the namespace " + xmlTxtRd.NamespaceURI);  

  304.  

  305. }  

  306. }  

  307. }  

  308. }  

  309. }  

  310. catch(XmlException xmlExp)  

  311. {  

  312. throw new XmlException(_errMsg + this._xmlPath + xmlExp.ToString());  

  313. }  

  314. finally  

  315. {  

  316. if (this.xmlTxtRd != null)  

  317. this.xmlTxtRd.Close();  

  318. }  

  319. }  

  320.  

  321. /// <summary>  

  322. /// 读取整个Xml文件  

  323. /// </summary>  

  324.  

  325. public void ReadXml()  

  326. {  

  327. string attAndEle = string.Empty;  

  328. this._listBox.Items.Clear();  

  329. this.xmlTxtRd = new XmlTextReader(this._xmlPath);  

  330.  

  331. try  

  332. {  

  333. while(xmlTxtRd.Read())  

  334. {  

  335. if (xmlTxtRd.NodeType == XmlNodeType.XmlDeclaration)  

  336. this._listBox.Items.Add(string.Format("<?{0} {1} ?>",
    xmlTxtRd.Name,xmlTxtRd.Value));  

  337. else if (xmlTxtRd.NodeType == XmlNodeType.Element)  

  338. {  

  339. attAndEle = string.Format("<{0} ",xmlTxtRd.Name);  

  340. if (xmlTxtRd.HasAttributes)  

  341. {  

  342. while(xmlTxtRd.MoveToNextAttribute())  

  343. {  

  344. attAndEleattAndEle = attAndEle + string.Format("{0}='{1}' 
    ",xmlTxtRd.Name,xmlTxtRd.Value);  

  345. }  

  346. }  

  347.  

  348. attAndEleattAndEle = attAndEle.Trim() + ">";  

  349. this._listBox.Items.Add(attAndEle);  

  350. }  

  351. else if (xmlTxtRd.NodeType == XmlNodeType.EndElement)  

  352. this._listBox.Items.Add(string.Format("</{0}>",xmlTxtRd.Name));  

  353. else if (xmlTxtRd.NodeType == XmlNodeType.Text)  

  354. this._listBox.Items.Add(xmlTxtRd.Value);  

  355. }  

  356. }  

  357. catch(XmlException xmlExp)  

  358. {  

  359. throw new XmlException(_errMsg + this._xmlPath + xmlExp.ToString());  

  360. }  

  361. finally  

  362. {  

  363. if (this.xmlTxtRd != null)  

  364. this.xmlTxtRd.Close();  

  365. }  

  366. }  

  367. }  

到此,相信大家对“C#如何使用XML”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

C#如何使用XML

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C#如何使用XML

本篇内容主要讲解“C#如何使用XML”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#如何使用XML”吧!C#如何使用XML对于XML,想必各位都比较了解,我也就不用费笔墨来描述它是什么了,我想
2023-06-18

如何用C#创建XML

本篇内容介绍了“如何用C#创建XML”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!C#创建XML文档通过.Net FrameWork SDK
2023-06-18

C#中如何使用XmlTextWriter创建XML文件

这篇文章将为大家详细讲解有关C#中如何使用XmlTextWriter创建XML文件,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。XmlTextWriter对象简介:XmlTextWriter
2023-06-17

C#.NET如何操作XML

小编给大家分享一下C#.NET如何操作XML,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!如何让C#.NET操作XML?需要添加的命名空间:using System.Xml;要完成C#.NET操作XML,首先定义几个公共对
2023-06-18

如何使用python xml模块

本篇内容主要讲解“如何使用python xml模块”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用python xml模块”吧!一、xml简介xml是实现不同语言或程序之间进行数据交换的协
2023-06-07

如何使用 PHP 解析 XML?

解析 xml 的方法:simplexml:使用对象语法,解析简单 xml 文档。domdocument:提供对 xml 文档的精细控制。如何在 PHP 中解析 XML解析 XML 是 web 开发中一项常见任务,PHP 提供了几种解析 X
如何使用 PHP 解析 XML?
2024-04-20

c语言如何解析xml

解析 xml 的 c 语言方法:直接解析:使用手动编写的代码或第三方库(如 expat、libxml2)。利用库:使用预先编写的库,如 expat、libxml2 或 tinyxml。使用 dom(文档对象模型):使用对象模型以树状结构访问
c语言如何解析xml
2024-05-21

C#如何使⽤XmlReader和XmlWriter操作XML⽂件

本文小编为大家详细介绍“C#如何使⽤XmlReader和XmlWriter操作XML⽂件”,内容详细,步骤清晰,细节处理妥当,希望这篇“C#如何使⽤XmlReader和XmlWriter操作XML⽂件”文章能帮助大家解决疑惑,下面跟着小编的
2023-06-30

如何正确使用PHP DOM-XML创建XML文件

如何正确使用PHP DOM-XML创建XML文件,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。我们在创建XML文件并对其进行解析时,通常都会用到PHP DOM-XML。那么
2023-06-17

使用Spring Aop如何配置xml

本篇文章给大家分享的是有关使用Spring Aop如何配置xml,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。AOP的配置方式有2种方式:xml配置和AspectJ注解方式。今
2023-05-31

如何使用jQuery来解析XML

这篇文章主要介绍了如何使用jQuery来解析XML,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。使用jQuery来解析XMLfunction parseXml(xml) {/
2023-06-27

C++怎么使用TinyXML解析XML

这篇文章主要介绍“C++怎么使用TinyXML解析XML”,在日常操作中,相信很多人在C++怎么使用TinyXML解析XML问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++怎么使用TinyXML解析XML
2023-06-22

C语言如何允许在对象中使用 XML 解析器

C语言本身不支持对象和XML解析,但可以通过以下方式实现:使用面向对象库:提供对象模型和XML解析功能,如Libxml2和Expat。使用XML解析API:提供解析XML数据的函数和数据结构,如libxml和Xerces-C++。优点:简化解析过程增强代码可读性利用现有功能缺点:增加依赖性和复杂性需要理解第三方库/API
C语言如何允许在对象中使用 XML 解析器
2024-04-02

C#如何实现XML序列化

这篇文章给大家分享的是有关C#如何实现XML序列化的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。实现C# XML序列化技术使用到什么具体的方法呢?我们在具体的操作过程中需要注意什么呢?那么这里向你展示一个Demo
2023-06-17

C#下怎么使用XmlDocument操作XML

在C#中,可以使用XmlDocument类来操作XML文件。以下是一个简单的示例,演示如何使用XmlDocument来创建、修改和读取XML文件。创建XML文件:```XmlDocument xmlDoc = new XmlDocument
2023-08-16

JavaSE XML解析技术如何使用

本文小编为大家详细介绍“JavaSE XML解析技术如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaSE XML解析技术如何使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。XML解析技术XML解
2023-07-06

如何使用Python读取xml文件

这篇文章主要介绍了如何使用Python读取xml文件,关于python读取xml文章很多,但大多文章都是贴一个xml文件,然后再贴个处理文件的代码希望这篇文章可以更通俗易懂的教如何使用python来读取xml文件
2023-05-15

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录