我现在有一个XML
<?xml version="1.0" encoding="utf-8" ?>
<root>
  <date>
    <DateNow>2005-06-29 12:05:42</DateNow>
  </date>
  <source>
    <ChannelGuid>AAAA</ChannelGuid>
  </source>
  <source>
    <ChannelGuid>BBBB</ChannelGuid>
  </source>
</root>我使用如下代码:
        Dim dstXML As New DataSet
        dstXML.ReadXml("e:\tracker\Synet.xml")
        ddlXML.DataSource = dstXML
        ddlXML.DataBind()ddlXML是一个DataGrid,现在只能显示的是date的数据,我要如何才能显示后面的那个ChannelGuid呢?同时我在其他地方还要调用那个Date,请问应该如何操作?

解决方案 »

  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);//显示子节点点文本
        }
       }
      

  2.   

    string xmlFilename = "myXmlDocument.xml";
    DataSet newDataSet = new DataSet("Data");
    newDataSet.ReadXml(xmlFilename);
    DataGrid1.DataSource = newDataSet;
    DataGrid1.DataBind();
    http://dotnet.aspx.cc/ShowDetail.aspx?id=016B3B65-7F4B-4146-BC97-9542D6F91AC4
      

  3.   

    显示XML文件内容
    用C#编程实现显示XML文件中信息的方法是使用.NET提供的标准类把XML文件内容读入一个StreamReader类对象中,再用XmlDataDocument类的DataSet读XML的方法去读XML信息到DataSet中,DataSet再以DataView的方式赋给一个Web Form上的DataGrid,最后由DataBind显示数据,具体实现代码如下: using System.Xml;
    //处理XML必须加的Namespace,还需在References中加System.XML.Dll
    using System.IO; 
    //读XML文件必须加的Namespace
     
    然后在Page_Load中加入如下代码: protected void Page_Load(object sender, EventArgs e){ 
    string datafile="guest.xml" ; 
    //假设XML文件名为guest.xml
    StreamReader tyj=new StreamReader(Server.MapPath(datafile));
    XmlDataDocument datadoc = new XmlDataDocument(); 
    //创建该对象为了读取XML
    datadoc.DataSet.ReadXml(tyj);
    //读取guest.xml文件内容
    DataGrid1.DataSource = datadoc.DataSet.Tables[0].DefaultView;
    //设置DataGrid数据源
    DataGrid1.DataBind();
    //绑定
    datadoc=null ; 
    //释放资源
    tyj.Close();}
    //释放StreamReader类,这非常重要,否则下次打开会显示文件已经被使用
     
    对应于显示用的Web Form中DataGrid的功能,我们需要增加下面的函数: protected void OnSelectName(object sender,EventArgs e) {
    Session["select_name"]=(string)DataGrid1.SelectedItem.Cells[1].Text.ToString();
    //把选定的 DataGrid某行中的一个单元中的值(Name)存入一个会话变量中,以便下一页用
    Response.Redirect("xml_manage.aspx");} 
    //转到有增加删除功能的管理页
     
    Web Form加入以下代码: <asp:DataGrid id=DataGrid1 runat="server" onselectedindexchanged="OnSelectName" >
    <property name="Columns">
    <asp:buttoncolumn Text="选择" commandname="Select" />
    </property>
     
    代码的作用是当按了“选择”按钮后,执行OnSelectName()中的程序,把选定的 DataGrid中某行中的一个单元中的值(Name)存入一个会话变量中,然后转到下一页。 
    增加XML文件内容 
    在Web Form中增加相应的几个TextBox和一个用于提交的Button,如本文附图所示,并为这button增加如下代码: string datafile = "guest.xml" ;XmlDocument xmldocument = new XmlDocument() ;
    xmldocument.Load(Server.MapPath(datafile)) ; 
    //把guest.xml读到xmldocument中
    DocumentNavigator navigator = new DocumentNavigator(xmldocument) ;
    //最重要的类
    navigator.MoveToDocumentElement() ;
    navigator.Insert(System.Xml.TreePosition.FirstChild, XmlNodeType.Element, 
    "Guest","","") ;//插入节点Guest
    navigator.Insert(System.Xml.TreePosition.FirstChild, XmlNodeType.Element, 
    "Name","","") ;
    navigator.Insert(System.Xml.TreePosition.FirstChild, XmlNodeType.Text,"Name","","") 
    ;
    navigator.Value=Name.Text ; 
    //为该节点赋值
    navigator.MoveToParent() ; 
    //返回父节点 Guest
    ……
    //使用同类语句,在元素Name下插入另一些元素如Country、E-mail地址和留言等
    xmldocument.Save(Server.MapPath(datafile));
    //最后保存这个XML文档
    navigator=null ;
    xmldocument=null ; 
    //释放XML文档,这样其他程序可以用它
     
    上述代码使用DocumentNavigator类增加元素和内容,注意使用后要释放资源。 
    删除XML文件内容 
    删除选定记录,对于你上面选择的节点,下面代码可查找到该节点并清除选中的信息: string datafile = "guest.xml" ;
    XmlDocument xmldocument = new XmlDocument() ;
    xmldocument.Load(Server.MapPath(datafile)) ; 
    //把guest.xml读到xmldocument中
    DocumentNavigator navigator = new DocumentNavigator(xmldocument) ;
    navigator.MoveToDocumentElement() ;
    navigator.Select("/Guests/Guest[Name='"+Session["select_name"]+"']");
    //参数是Xpath
    navigator.RemoveSelected(); 
    //执行删除
    xmldocument.Save(Server.MapPath(datafile));
    //最后保存这个XML文档
    navigator=null;
    //释放类
    xmldocument=null ; 
    //释放XML文档,这样其他程序可以用它
     
    如需将XML文件中所有信息清除,使用“navigator.RemoveChildren();”语句即可实现。
      

  4.   

    string xmlFilename = "myXmlDocument.xml";
    DataSet newDataSet = new DataSet();
    newDataSet.ReadXml(xmlFilename);
    DataGrid1.DataSource = newDataSet;
    DataGrid1.DataBind();这种方法是最简单的,只要你的XML不会说没有表的结构规律就可以了。恩