XmlDocument doc = new XmlDocument();
XmlDataDocument docData = new XmlDataDocument(ds);//ds,是DataSet对象
doc = docData;
         XmlTextWriter writer = new XmlTextWriter(Page.MapPath("DOC/")+"data.xml",null);
         writer.Formatting = Formatting.Indented;
         doc.Save(writer);
writer.Close();
大家看看这个代码,生成后的XML文件,默认的是<?xml version="1.0"?>,这个我想改成
<?xml version='1.0' encoding='gb2312'?>
<?xml-stylesheet type='text/xsl' href='../template/news.xsl'?>这个用XmlDocument怎么操作,谢谢指教。

解决方案 »

  1.   

    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>
      <book genre="李赞红" ISBN="2-3631-4">
        <title>CS从入门到精通</title>
        <author>候捷</author>
        <price>58.3</price>
      </book>
    </bookstore>
    增加操作================================================================
    XmlDocument xmlDoc=new XmlDocument(); 
    xmlDoc.Load(Server.MapPath("test.xml")); 
    XmlNode root=xmlDoc.SelectSingleNode("bookstore");//查找<bookstore> 
    XmlElement xe1=xmlDoc.CreateElement("book");//创建一个<book>节点 
    xe1.SetAttribute("genre","李赞红");//设置该节点genre属性 
    xe1.SetAttribute("ISBN","2-3631-4");//
    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(Server.MapPath("test.xml")); 
    修改操作===============================================================================
    XmlDocument xmlDoc=new XmlDocument(); 
    xmlDoc.Load(Server.MapPath("test.xml")); 

    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(Server.MapPath("test.xml")); 
    }
    删除操作=======================================================================
    XmlDocument xmlDoc=new XmlDocument(); 
    xmlDoc.Load(Server.MapPath("test.xml")); 

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

    XmlElement xe=(XmlElement)xn; 
    if(xe.GetAttribute("genre")=="fantasy") 

    xe.RemoveAttribute("genre");//删除genre属性 

    else if(xe.GetAttribute("genre")=="update李赞红") 

    xe.RemoveAll();//删除该节点的全部内容 


       xmlDoc.Save(Server.MapPath("test.xml")); 
    显示数据==============================================================================
    XmlDocument xmlDoc=new XmlDocument(); 
    xmlDoc.Load(Server.MapPath("test.xml")); 

    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) 

    Response.Write(xn2.InnerText);//显示子节点点文本 

    }
      

  2.   

    TO:sunjay117(sunjay117),非常谢谢你的说明,但<?xml-stylesheet type='text/xsl' href='../template/news.xsl'?>,这个我如何操作呀,是不是要用到system.xml.xsl