用户登录
用户注册

分享至

XML 增、删、改和查示例

  • 作者: 羞涩me糖果
  • 来源: 51数据库
  • 2021-07-04

1.已知有一个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);//显示子节点点文本
    }
   }


留做参考,原文地址http://blog.yesky.com/75/richsee/1211075.shtml

2前台代码:html

xml文件dbguest.xml
软件
前端设计
程序设计
Java相关