随着不断的学习,对asp.net c#的了解,越来越觉得xml很好,但是有些还是要和sql联用,并不象有些人夸大说的替代sql了,这里讲讲我自己的用的一些经验。

asp.net创建xml就是通过创建DataTable来创建xml中的树型等

 1 DataSet objset=new DataSet();
 2         DataTable istable=new DataTable("test");
 3         istable.Columns.Add("rate1",typeof(int));
 4                 istable.Columns.Add("rate2",typeof(int));
 5                 istable.Columns.Add("rate3",typeof(int));
 6                 istable.Columns.Add("rate4",typeof(int));
 7         objset.Tables.Add(istable);
 8         
 9         DataRow dr=objset.Tables["test"].NewRow();
10         dr[0]=赋值;
11         dr[1]=赋值;
12         dr[2]=赋值;
13         dr[3]=赋值;
14         objset.Tables["money"].Rows.Add(dr);
15         
16         objset.WriteXml(Server.MapPath("test.xml"),XmlWriteMode.WriteSchema);

其中就是先创建DataSet和DataTable,其中建立的表为test,再在表中添加子项rate1,2,3,4,再定义新的行,分别添加对应的值,最后这些都已经写进DataSet表中,通过DataSet把xml输入就完成了。要读就只需要把xml的数据读到DataSet中,再通过DataSet中的表的项来对应读出数据。

而C#中则使用的DOM来实现操作,比如现有一个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>
        下面讲解4种常用的方法

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

以上的就是ASP.NET和C#对xml的基本使用方法。下面说一下xml和xsl,从抽象的来说,我个人觉得xml象是数据库,而xsl就象是过滤的。xsl中可以加入html等语法,也可以加入xml的语法等,可以列出需要的数据等。
现有一个xml文件,内容如下

<?xml version="1.0"?>
<?xml-stylesheet type="text/xsl" href="test.xsl"?>
<NewDataSet>
 <Table id="1">
    <ProductID>1001</ProductID>
    <CategoryID>1</CategoryID>
 </Table>
 <Table id="2">
    <ProductID>1002</ProductID>
    <CategoryID>2</CategoryID>
 </Table>
</NewDataSet>

其中第2句是引用xsl,xsl内容如下

<?xml version="1.0"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">
<xsl:template match="/">
<html>
     <body>
       <center>
       <h2>the notepad</h2>
       <table border="1">
           <tr>
                <td>id</td>
                <td>name</td>
           </tr>
      <xsl:for-each select="NewDataSet/Table">
           <tr>
                <td><xsl:value-of select="ProductID"/></td>
                <td><xsl:value-of select="ProductName"/></td>
            </tr>
      </xsl:for-each>
       </table>
       </center>
     </body>
    </html>
 </xsl:template>
</xsl:stylesheet>

中间的for-each就是循环遍历节点,获取指定的select后的内容,下面的value-of就相当于sql中字段名。在使用xsl的时候,还可以查询某一个值,这样xsl就需要如下<xsl:value-of select="/students/student[@id='2']/ProductID"/>

<?xml version="1.0" encoding="gb2312"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">
<xsl:template match="/">
<center> <h1>id号是"2"的厂家的产品ID是:<xsl:value-of select="/NewDataSet/Table[@id='2']/ProductID"/></h1></center>
 </xsl:template>
</xsl:stylesheet>

有些如果在Table下还有节点,要显示这个节点下的东西xsl就该如下

<?xml version="1.0"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">
<xsl:template match="/">
    <html>
     <body>
       <center>
       <h2>the notepad</h2>
       <table border="1">
           <tr>
                <td>随便写</td>
           </tr>
      <xsl:for-each select="NewDataSet/Table/xx/*">
           <tr>
                <td><xsl:value-of select="."/></td>
            </tr>
      </xsl:for-each>
       </table>
       </center>
     </body>
    </html>
</xsl:template>
</xsl:stylesheet>

差不多了,收工,呵呵,大家交流哈!

转载于:https://www.cnblogs.com/xujiaci/archive/2007/09/01/878193.html

ASP.NET和C#中对XML的操作,以及简单的xml与xsl !相关推荐

  1. java:AXIS调用webService接口,返回String类型xml,并用dom4j简单解析xml

    一.使用axis调用webService接口,返回String类型xml 1.导入axis依赖 2.直接贴代码 /*** 调用webservice接口的方法,并返回String类型的xml* @par ...

  2. java在线打开xml文件_java实现简单解析XML文件功能示例

    本文实例讲述了java实现简单解析XML文件功能.分享给大家供大家参考,具体如下: package demo; import java.io.File; import java.io.IOExcept ...

  3. ASP.NET 2.0中发送电子邮件

    ASP.NET 2.0中发送电子邮件 ASP.NET 2.0 中发送电子邮件变得非常简单.发送电子邮件的类库主要在命名空间System.Net.Mail中,在这个命名空间中有两个核心类是:       ...

  4. xml常用操作(js、sql、vb)

    我们经常会用到xml操作,如下介绍了js.sql.vb等对xml的操作. JS创建xml对象 //创建对象 function getDataXML() {var objTds = $("TE ...

  5. matlab对xml文件操作,Matlab读写xml文件

    xml文件以文档对象模型表示,简称DOM(Document Object Model).在Matlab中,使用xmlread读取xml文件成DOM节点,对xml文件的操作转化成对DOM节点的操作,使用 ...

  6. tinyxml2 数组_7.数据本地化CCString,CCArray,CCDictionary,tinyxml2,写入UserDefault.xml文件,操作xml,解析xml...

     数据本地化 A CCUserDefault 系统会在默认路径cocos2d-x-2.2.3\projects\Hello\proj.win32\Debug.win32下生成一个名为UserDef ...

  7. 新浪微博 XML 文件操作助手

    TAG: 新浪微博 XML 文件操作助手 API /// <summary> /// XML 文件操作助手 /// </summary> public class XmlHel ...

  8. (四)Asp.net web api中的坑-【api的返回值】

    (四)Asp.net web api中的坑-[api的返回值] 原文:(四)Asp.net web api中的坑-[api的返回值] void无返回值 IHttpActionResult HttpRe ...

  9. 在ASP.NET 2.0中建立站点导航层次

    站点导航提供程序--ASP.NET 2.0中的站点导航提供程序暴露了应用程序中的页面的导航信息,它允许你单独地定义站点的结构,而不用考虑页面的实际物理布局.默认的站点导航提供程序是基于XML的,但是你 ...

  10. Android中measure过程、WRAP_CONTENT详解以及 xml布局文件解析流程浅析

    转自:http://www.uml.org.cn/mobiledev/201211221.asp 今天,我着重讲解下如下三个内容: measure过程 WRAP_CONTENT.MATCH_PAREN ...

最新文章

  1. react-native-webview禁止缩放
  2. 蓝桥杯-送分啦(java)
  3. GBin1专题之Web热点秀#15
  4. 微型计算机中的奔四指的是,2015云南省计算机等级考试二级理论考试试题及答案...
  5. eclipse中添加插件的方法
  6. C/C++排序算法(2)希尔排序
  7. itchat key
  8. Q123:PBRT-V3,各种形式的“光传播方程”的推导依据
  9. JMETER 不同线程组 变量值 的参数传递(转)
  10. php赛车,php调用接口及三分赛车平台搭建出租编写接口
  11. [转]GDI+ 中发生一般性错误解决方案
  12. linux版 tar.bz2如何解压,Linux下*.tar.bz2等文件如何解压--转
  13. 锐起无盘找不到服务器,锐起无盘出现重启后连接不到服务器
  14. linux bt 命令行,linux命令行bt下载工具
  15. MODIS数据批量下载
  16. 软考中级软件设计师--考试准备
  17. VS2013 VS2015应用程序无法正常启动0xc000007b。
  18. 关于 未受信任的企业级开发者 提示的解决
  19. java二级程序题两个角度_两个角度图_【SCME大一】使用JAVA语言深入理解程序逻辑答案_学小易找答案...
  20. Linux是什么 ?

热门文章

  1. SAP 中如何寻找增强
  2. Linux 应用程序开发入门
  3. AtomicInteger相关类
  4. js获取datagrid行,但是行改变了肿么办?
  5. 【转】DB2学习路线
  6. Oracle10.2.0.1.0升级Oracle10.2.0.2.0补丁安装指南(转载)
  7. 时尚的基因是创新 -- 旺旺平台产品线员工大会即兴发言提要
  8. MySQL5 基础语法与操作
  9. 远程接入-天翼5系统让ERP穿越时空!
  10. Hadoop HA 双namenode搭建