什么是XML?

解析:XML:Extensible Markup Language(可扩展标记语言)

HTML:HyperLink Text  Markup Language(超文本标记语言)

xml文件和html文件的区别?

解析:01.xml严格区分大小写,html不区分

02.xml不是编译语言,xml和html都是解释型语言

03.html语言负责显示数据,而Xml文件就是专门用来存储数据

001.对已有的Xml文档进行读取

eg:

第一步:创建一个Xml文档

 //Xml文档
<?xml version="1.0" encoding="utf-8" ?>
<Computers>
<computer>
<Name>LenovoY系列</Name>
<Price>5000</Price>
<Cpu>CORE i3</Cpu>
</computer>
<computer>
<Name>DELL YY</Name>
<Price>7000</Price>
<Cpu>CORE i7</Cpu>
</computer>
</Computers>

第二步:将创建好的Xml文档放入到指定文件中

看,法宝!.......不,看图

第三部:在main函数中写对Xml文档的操作代码

 #region 01.用双foreach遍历
XmlDocument doc = new XmlDocument();
doc.Load("Computer.xml");
XmlNode root = doc.DocumentElement;
//root为一个根节点对象
foreach(XmlNode item in root.ChildNodes)
{
foreach(XmlNode computer in item.ChildNodes)
{
switch (computer.Name)
{
case "Name":
Console.WriteLine("电脑的名称为:"+computer.InnerText);
break;
case "Price":
Console.WriteLine("电脑的价格为:"+computer.InnerText);
break;
case "Cpu":
Console.WriteLine("电脑的CPU为:"+computer.InnerText);
break;
}
#endregion

002.对Xml文档进行修改

 <?xml version="1.0" encoding="gb2312"?>

 <bookstore>

 <book genre="fantasy" ISBN="2-3631-4">

 <title>Oberon's Legacy</title>

 <author>Corets, Eva</author>

 <price>5.95</price>

 </book>

 </bookstore>
 //将genre属性值为“李赞红“的节点的genre值改为“update李赞红”,将该节点的子节点<author>的文本修改为“亚胜”。

 XmlNodeList nodeList=xmlDoc.SelectSingleNode("bookstore").ChildNodes;//获取bookstore节点的所有子节点

 foreach(XmlNode xn in nodeList)//遍历XML文档所有子节点

 {

 XmlElement xe=(XmlElement)xn;//将子节点类型转换为XmlElement类型

 if(xe.GetAttribute("genre")=="李赞红")//如果genre属性值为“李赞红”

 {

 xe.SetAttribute("genre","update李赞红");//则修改该属性为“update李赞红”

 XmlNodeList nls=xe.ChildNodes;//继续获取xe子节点的所有子节点

 foreach(XmlNode xn1 in nls)//遍历

 {

 XmlElement xe2=(XmlElement)xn1;//转换类型

 if(xe2.Name=="author")//如果找到

 {

 xe2.InnerText="亚胜";//则修改

 break;//找到退出来就可以了

 }

 }

 break;

 }

 }

 xmlDoc.Save("bookstore.xml");//保存。

 //=================

 最后结果为:

 <?xml version="1.0" enc

 oding="gb2312"?>

 <bookstore>

 <book genre="fantasy" ISBN="2-3631-4">

 <title>Oberon's Legacy</title>

 <author>Corets, Eva</author>

 <price>5.95</price>

 </book>

 <book genre="update李赞红" ISBN="2-3631-4">

 <title>CS从入门到精通</title>

 <author>亚胜</author>

 <price>58.3</price>

 </book>

 </bookstore>-->

003.对Xml文档新增节点

 //往<bookstore>节点中插入一个<book>节点:

 XmlDocument xmlDoc=new XmlDocument();

 xmlDoc.Load("bookstore.xml");

 XmlNode root=xmlDoc.SelectSingleNode("bookstore");//查找<bookstore>

 XmlElement xe1=xmlDoc.CreateElement("book");//创建一个<book>节点

 xe1.SetAttribute("genre","李赞红");//设置该节点genre属性

 xe1.SetAttribute("ISBN","2-3631-4");//设置该节点ISBN属性

 XmlElement xesub1=xmlDoc.CreateElement("title");

 xesub1.InnerText="CS从入门到精通";//设置文本节点

 xe1.AppendChild(xesub1);//添加到<book>节点中

 XmlElement xesub2=xmlDoc.CreateElement("author");

 xesub2.InnerText="候捷";

 xe1.AppendChild(xesub2);

 XmlElement xesub3=xmlDoc.CreateElement("price");

 xesub3.InnerText="58.3";

 xe1.AppendChild(xesub3);

 root.AppendChild(xe1);//添加到<bookstore>节点中

 xmlDoc.Save("bookstore.xml");

 //================

 结果为:

 <?xml version="1.0" encoding="gb2312"?>

 <bookstore>

 <book genre="fantasy" ISBN="2-3631-4">

 <title>Oberon's Legacy</title>

 <author>Corets, Eva</author>

 <price>5.95</price>

 </book>

 <book genre="李赞红" ISBN="2-3631-4">

 <title>CS从入门到精通</title>

 <author>候捷</author>

 <price>58.3</price>

 </book>

 </bookstore>

(二).对treeview进行操作

首先新建一个TreeView控件

课堂博客-----TreeView+++++XML形成博客的更多相关文章

  1. MWeb 1.3.7 发布!增加发布到 Wordpress 等支持 MetaWeblog API 的服务,如:Wordpress 博客、新浪博客、cnblogs、oschina。

    MWeb 1.3.7 版的新功能 增加发布到 Wordpress 等支持 Metaweblog API 的服务,目前经测试过的有: Wordpress 博客.新浪博客.cnblogs.oschina. ...

  2. asp.net批量发布博客到各大博客平台

    新浪博客 http://upload.move.blog.sina.com.cn/blog_rebuild/blog/xmlrpc.php 网易博客 http://os.blog.163.com/ap ...

  3. 继网易博客后搜狐博客也增加了nofollow标签

    继网易博客后搜狐博客也增加了nofollow标签 今天在搜狐博客发表了篇文章,在末端添加上我的版权,结果回头查看是发现,这个锚文本被加上了nofollow标签,也就是说这样的外链已经没有传递权重的作用 ...

  4. 【博客导航】Nico博客导航汇总

    摘要 介绍本博客关注的内容大类.任务.工具方法及链接,提供Nico博文导航. 导航汇总 [博客导航]Nico博客导航汇总 [导航]信息检索导航 [导航]Python相关 [导航]读书导航 [导航]FP ...

  5. Node.js 从零开发 web server博客项目[express重构博客项目]

    web server博客项目 Node.js 从零开发 web server博客项目[项目介绍] Node.js 从零开发 web server博客项目[接口] Node.js 从零开发 web se ...

  6. Node.js 从零开发 web server博客项目[koa2重构博客项目]

    web server博客项目 Node.js 从零开发 web server博客项目[项目介绍] Node.js 从零开发 web server博客项目[接口] Node.js 从零开发 web se ...

  7. 转载自jguangyou的博客,XML基本属性大全

    android:layout_width 指定组件布局宽度 android:layout_height 指定组件布局高度 android:alpha 设置组件透明度 android:backgroun ...

  8. Android为TV端助力 转载自jguangyou的博客,XML基本属性大全

    android:layout_width 指定组件布局宽度 android:layout_height 指定组件布局高度 android:alpha 设置组件透明度 android:backgroun ...

  9. 使用django开发博客过程记录3——博客侧栏实现

    说起这个侧栏真是苦恼我很长时间,一开始以为和之前的一样传递额外参数就可以了就像下面这样: class IndexView(ListView): template_name = 'apps/index. ...

随机推荐

  1. 从零开始搭建Salt Web之封装salt-api接口

    salt-api现在已经正常运行,接下来则是实现通过调用salt-api来执行salt命令. 调用salt-api执行命令时,记得携带c_path参数 因为salt中自带了tornado这个库,所以决 ...

  2. 卷积神经网络(CNN)反向传播算法

    在卷积神经网络(CNN)前向传播算法中,我们对CNN的前向传播算法做了总结,基于CNN前向传播算法的基础,我们下面就对CNN的反向传播算法做一个总结.在阅读本文前,建议先研究DNN的反向传播算法:深度 ...

  3. Unity3D换装系统

    转载请注明出处:http://www.cnblogs.com/shamoyuu/p/6505561.html 一.换装原理 游戏角色换装分为以下几步: 1.替换蒙皮网格 2.刷新骨骼 3.替换材质 上 ...

  4. H5移动端开发入门知识以及CSS的单位汇总与用法

    说到css的单位,大家应该首先想到的是px,也就是像素,我们在网页布局中一般都是用px,但是近年来自适应网页布局越来越多,em和百分比也经常用到了.然后随着手机的流行,web app和hybrid a ...

  5. MySQL之乱码问题解决详解

    今天在写一个项目的时候,在数据库中手动插入数据不会产生中文乱码,但是通过javaWeb却出现乱码,把提交表单和响应中的乱码问题解决后,还是乱码.所以我锁定一定是我的mysql数据库中出现了乱码的现象.

  6. 向php提交数据及json

    php中提交表单有两种方法,即: (1)利用表单提交 例: <form action="php文件名" method='提交方式'> username:<inpu ...

  7. js实现Mac触摸板双指事件(上、下、左、右、放大、缩小)

    前言 这几天在修复一个web问题时,需要捕获Mac触摸板双指事件(上.下.左.右.放大.缩小),但发现并没有现成的轮子,还是要自己造. 例如:jquery.mousewheel.js(添加跨浏览器的鼠 ...

  8. 1197: [HNOI2006]花仙子的魔法

    1197: [HNOI2006]花仙子的魔法 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 762  Solved: 443[Submit][Stat ...

  9. 1191: [HNOI2006]超级英雄Hero

    1191: [HNOI2006]超级英雄Hero Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1996  Solved: 946[Submit][S ...

  10. virtualBox,webstorm,开虚拟机传代码

    一起git一个新技能 利用virtualBOX在本地开一个虚拟机,然后设置webstorm连接到虚拟机,将代码传到虚拟机里. 以下详细讲解: 第一步: 第二步:管理虚拟机的设置(我是用的是Xshell ...