CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
不看会后悔的Windows XP之经验谈 简单快捷DIY实用家庭影院
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  .NET技术 >  VB.NET

如何从XML中读取数据

楼主xiaowengang(海岛)2005-12-02 18:06:27 在 .NET技术 / VB.NET 提问

<rootElement>  
  <childElement   key="1"   value="aaa"/>  
  <childElement   key="2"   value="bbb"/>  
  </rootElement>  
   
  上面是我建的XML文件,我想从中读值,请问各位高人应怎样做? 问题点数:40、回复次数:3Top

1 楼jiang8282(雪山飞狐)回复于 2005-12-02 18:20:51 得分 6

DataSet   可以读出  
  Element   也可以读出.  
   
  Top

2 楼BearRui(孤熊 | 带你去看海!)回复于 2005-12-02 18:21:10 得分 4

用XmlDocument,具体用法可以看MSDN,或者在网上搜索下就会有很多例子了!!!Top

3 楼hanbb1982(粤饶字号@0768)回复于 2005-12-02 20:16:17 得分 30

已知有一个XML文件(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>  
  </bookstore>  
     
  1、往<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>  
     
  2、修改节点:将genre属性值为“李赞红“的节点的genre值改为“update李赞红”,将该节点的子节点<author>的文本修改为“亚胜”。  
          XmlNodeList   nodeList=xmlDoc.SelectSingleNode("bookstore").ChildNodes;//获取bookstore节点的所有子节点  
        foreach(XmlNode   xn   in   nodeList)//遍历所有子节点  
        {  
          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"   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="update李赞红"   ISBN="2-3631-4">  
          <title>CS从入门到精通</title>  
          <author>亚胜</author>  
          <price>58.3</price>  
      </book>  
  </bookstore>  
     
  3、删除   <book   genre="fantasy"   ISBN="2-3631-4">节点的genre属性,删除   <book   genre="update李赞红"   ISBN="2-3631-4">节点。  
  XmlNodeList   xnl=xmlDoc.SelectSingleNode("bookstore").ChildNodes;  
     
        foreach(XmlNode   xn   in   xnl)  
        {  
          XmlElement   xe=(XmlElement)xn;  
          if(xe.GetAttribute("genre")=="fantasy")  
          {  
            xe.RemoveAttribute("genre");//删除genre属性  
          }  
          else   if(xe.GetAttribute("genre")=="update李赞红")  
          {  
            xe.RemoveAll();//删除该节点的全部内容  
          }  
        }  
        xmlDoc.Save("bookstore.xml");  
  //===========================================  
  最后结果为:  
  <?xml   version="1.0"   encoding="gb2312"?>  
  <bookstore>  
      <book   ISBN="2-3631-4">  
          <title>Oberon's   Legacy</title>  
          <author>Corets,   Eva</author>  
          <price>5.95</price>  
      </book>  
      <book>  
      </book>  
  </bookstore>  
     
  4、显示所有数据。  
        XmlNode   xn=xmlDoc.SelectSingleNode("bookstore");  
     
        XmlNodeList   xnl=xn.ChildNodes;  
         
        foreach(XmlNode   xnf   in   xnl)  
        {  
          XmlElement   xe=(XmlElement)xnf;  
          Console.WriteLine(xe.GetAttribute("genre"));//显示属性值  
          Console.WriteLine(xe.GetAttribute("ISBN"));  
     
          XmlNodeList   xnf1=xe.ChildNodes;  
          foreach(XmlNode   xn2   in   xnf1)  
          {  
            Console.WriteLine(xn2.InnerText);//显示子节点点文本  
          }  
        }    
   
  Top

相关问题

  • 如何读取XML Schema中的数据?
  • 读取 XML 数据岛
  • 如何刷新利用 DOM 读取 XML 数据岛?
  • 如何利用客户端脚本读取xml数据?
  • 如何利用客户端脚本读取xml数据?
  • 关于如何使用ASP读取XML数据库的问题。
  • 如何读取XML文件中的数据?
  • DataSet如何读取XML中的节点数据
  • cell 3.x 版表格如何读取xml数据或SQL SERVER 数据?
  • 如何动态创建XML文件,并添加数据、读取数据

关键词

  • 节点
  • 属性
  • 修改
  • 文本
  • xe
  • genre
  • xmlelement
  • xesub
  • xmldoc
  • xn

得分解答快速导航

  • 帖主:xiaowengang
  • jiang8282
  • BearRui
  • hanbb1982

相关链接

  • CSDN .NET频道
  • .NET类图书
  • C#类图书
  • .NET类源码下载

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
北京创新乐知广告有限公司 版权所有, 京 ICP 证 070598 号
世纪乐知(北京)网络技术有限公司 提供技术支持
Copyright © 2000-2008, CSDN.NET, All Rights Reserved
GongshangLogo