zoukankan      html  css  js  c++  java
  • Xml中SelectSingleNode方法,xpath查找某节点用法

    转自:https://www.cnblogs.com/love201314/p/5589784.html

    最常见的XML数据类型有:Element, Attribute,Comment, Text. Element, 指形如<Name>Tom<Name>的节点。它可以包括:Element, Text, Comment, ProcessingInstruction, CDATA, and EntityReference.

       Attribute, 指在<Employee >中的粗体部分。

       Comment,指形如:<!-- my comment --> 的节点。

       Text,指在<Name>Tom<Name>的粗体部分。

      在XML中,可以用XmlNode对象来参照各种XML数据类型。

       2.1 查询已知绝对路径的节点(集)

       objNodeList = objDoc.SelectNodes(“Company/Department/Employees/Employee”)

      或者

       objNodeList = objNode.SelectNodes(“/Company/Department/Employees/Employee”)

      以上两种方法可返回一个NodeList对象,如果要返回单个节点可使用SelectSingleNode方法,该方法如果查询到一个或多个节点,返回第一个节点;如果没有查询的任何节点返回 Nothing。例如:

       objNode = objNode.SelectSingleNode(“/Company/Department/Employees/Employee”)

       If Not (objNode is Nothing) then

       ‘- Do process

       End If

       2.2 查询已知相对路径的节点(集)

      可使用类似于文件路径的相对路径的方式来查询XML的数据

       objNode = objDoc.SelectSingleNode(“Company/Department”)

       objNodeList = objNode.SelectNodes(“../Department)

       objNode = objNode.SelectNode(“Employees/Employee”)

       2.3 查询已知元素名的节点(集)

      在使用不规则的层次文档时,由于不知道中间层次的元素名,可使用//符号来越过中间的节点,查询其子,孙或多层次下的其他所有元素。例如:

       objNodeList = objDoc.SelectNodes(“Company//Employee”)

       2.4 查询属性(attribute)节点

      以上的各种方法都返回元素(element)节点(集),返回属性(attribute),只需要采用相应的方法,在属性名前加一个@符号即可,例如:

       objNodeList = objDoc.SelectNodes(“Company/Department/Employees/Employee/@id”)

       objNodeList = objDoc.SelectNodes(“Company//@id”)

       2.5 查询Text节点

      使用text()来获取Text节点。

       objNode = objDoc.SelectSingleNode(“Company/Department/Deparmt_Name/text()”)

       2.6 查询特定条件的节点

      使用[]符号来查询特定条件的节点。例如:

       a. 返回id号为 10102的Employee节点

       objNode = objDoc.SelectSingleNode(“Company/Department/Employees/Employee[@id=’10102’]”)

       b. 返回Name为Zhang Qi的Name 节点

       objNode = objDoc.SelectSingleNode(“Company/Department/Employees/Employee/Name[text()=’Zhang Qi’]”)

       c. 返回部门含有职员22345的部门名称节点

       objNode = objDoc.SelectSingleNode("Company/Department[Employees/Employee/@id='22345']/Department_Name")

       2.7 查询多重模式的节点

      使用 | 符号可以获得多重模式的节点。例如:

       objNodeList = objDoc.SelectNodes(“Company/Department/Department_Name | Company/Department/Manager”)

       2.8 查询任意子节点

      使用*符号可以返回当前节点的所有子节点。

       objNodeList = objDoc.SelectNodes(“Company/*/Manager)

      或者

       objNodeList = objNode.ChildNodes 

       3 XML数据的编辑

       3.1 增加一个元素的属性(attribute)节点

       Dim objNodeAttr As XmlNode

       objNodeAttr = objDoc.CreateAttribute("id", Nothing)

       objNodeAttr.InnerXml = "101"

       objNode.Attributes.Append(objNodeAttr)

       3.2 删除一个元素的属性

       objNode.Attributes.Remove(objNodeAttr)

       3.3 增加一个子元素(Element)

       Dim objNodeChild As XmlNode

       objNodeChild = objDoc.CreateElement(Nothing, "ID", Nothing)

       objNodeChild.InnerXml = "101"

       objNode.AppendChild(objNodeChild)

       3.4 删除一个子元素

       objNode.RemoveChild(objNodeChild)

       3.5 替换一个子元素

       objNOde.ReplaceChild(newChild,oldChild) 

     4 参考数据

     1 <?xml version="1.0" encoding="UTF-8"?>
     2 <Company>
     3     <Department>
     4         <Department_Name>Cai WuBu</Department_Name>
     5         <Manager>Zhang Bin</Manager>
     6         <Employees>
     7             <Employee>
     8                 <Employee_ID>12345</Employee_ID>
     9                 <Name>Zhang Bin</Name>
    10                 <Gender>male</Gender>
    11             </Employee>
    12             <Employee>
    13                 <Employee_ID>10101</Employee_ID>
    14                 <Name>Zhang QI</Name>
    15                 <Gender>female</Gender>
    16             </Employee>
    17             <Employee>
    18                 <Employee_ID>10102</Employee_ID>
    19                 <Name>Zhang Xia</Name>
    20                 <Gender>male</Gender>
    21             </Employee>
    22             <Employee>
    23                 <Employee_ID>10201</Employee_ID>
    24                 <Name>ZhangChuang</Name>
    25                 <Gender>male</Gender>
    26             </Employee>
    27             <Employee>
    28                 <Employee_ID>10202</Employee_ID>
    29                 <Name>Zhang Jun</Name>
    30                 <Gender>male</Gender>
    31             </Employee>
    32         </Employees>
    33     </Department>
    34     <Department>
    35         <Department_Name>KaiFa Bu</Department_Name>
    36         <Manager>Wang Bin</Manager>
    37         <Employees>
    38             <Employee>
    39                 <Employee_ID>22345</Employee_ID>
    40                 <Name>Wang Bin</Name>
    41                 <Gender>male</Gender>
    42             </Employee>
    43             <Employee>
    44                 <Employee_ID>20101</Employee_ID>
    45                 <Name>Wang QI</Name>
    46                 <Gender>female</Gender>
    47             </Employee>
    48             <Employee>
    49                 <Employee_ID>20102</Employee_ID>
    50                 <Name>Wang Xia</Name>
    51                 <Gender>male</Gender>
    52             </Employee>
    53             <Employee>
    54                 <Employee_ID>20201</Employee_ID>
    55                 <Name>Wang Chuang</Name>
    56                 <Gender>male</Gender>
    57             </Employee>
    58             <Employee>
    59                 <Employee_ID>20201</Employee_ID>
    60                 <Name>Wang Jun</Name>
    61                 <Gender>male</Gender>
    62             </Employee>
    63         </Employees>
    64     </Department>
    65 </Company>    

    C#用xpath查找某节点

      1 从根节点一直下来的相对路径才能确定Xpath的写法。
      2 
      3 /root/<节点1>/<节点2>//<@属性>
      4 
      5 Xpath是功能很强大的,但是也是相对比较复杂的一门技术,最好还是到博客园上面去专门找一些专业的帖子来看一看,下面是一些简单的Xpath语法和一个实例,提供给你参考一下
      6 
      7 
      8 <?xml version="1.0" encoding="ISO-8859-1"?>
      9 <catalog>
     10   <cd country="USA">
     11     <title>Empire Burlesque</title>
     12     <artist>Bob Dylan</artist>
     13     <price>10.90</price>
     14   </cd>
     15   <cd country="UK">
     16     <title>Hide your heart</title>
     17     <artist>Bonnie Tyler</artist>
     18     <price>9.90</price>
     19   </cd>
     20   <cd country="USA">
     21     <title>Greatest Hits</title> 
     22     <artist>Dolly Parton</artist> 
     23     <price>9.90</price> 
     24   </cd>
     25 </catalog>
     26 
     27          
     28 定位节点 
     29 XML是树状结构,类似档案系统内数据夹的结构,XPath也类似档案系统的路径命名方式。不过XPath 是一种模式(Pattern),可以选出 XML档案中,路径符合某个模式的所有节点出来。例如要选catalog底下的cd中所有price元素可以用: 
     30 
     31 
     32 /catalog/cd/price     
     33 
     34 如果XPath的开头是一个斜线(/)代表这是绝对路径。如果开头是两个斜线(//)表示文件中所有符合模式的元素都会被选出来,即使是处于树中不同的层级也会被选出来。以下的语法会选出文件中所有叫做cd的元素(在树中的任何层级都会被选出来): 
     35 
     36 
     37 //cd
     38 
     39 选择未知的元素 
     40 使用星号(Wildcards,*)可以选择未知的元素。下面这个语法会选出/catalog/cd 的所有子元素: 
     41 
     42 
     43 /catalog/cd/*
     44 
     45 以下的语法会选出所有catalog的子元素中,包含有price作为子元素的元素。
     46 
     47 
     48 /catalog/*/price
     49 
     50 以下的语法会选出有两层父节点,叫做price的所有元素。
     51 
     52 
     53 /*/*/price
     54 
     55 以下的语法会选择出文件中的所有元素。 
     56 
     57 
     58 //*
     59 
     60 要注意的是,想要存取不分层级的元素,XPath语法必须以两个斜线开头(//),想要存取未知元素才用星号(*),星号只能代表未知名称的元素,不能代表未知层级的元素。
     61 
     62 选择分支 
     63 使用中括号可以选择分支。以下的语法从catalog的子元素中取出第一个叫做cd的元素。XPath的定义中没有第0元素这种东西。 
     64 
     65 
     66 /catalog/cd[1]
     67 
     68 以下语法选择catalog中的最后一个cd元素:(XPathj并没有定义 first() 这种函式喔,用上例的 [1]就可以取出第一个元素。 
     69 
     70 
     71 /catalog/cd[last()]
     72 
     73 以下语法选出含有price子元素的所有/catalog/cd元素。 
     74 
     75 
     76 /catalog/cd[price]
     77 
     78 以下语法选出price元素的值等于10.90的所有/catalog/cd元素 
     79 
     80 
     81 /catalog/cd[price=10.90]
     82 
     83 以下语法选出price元素的值等于10.90的所有/catalog/cd元素 的price元素 
     84 
     85 
     86 /catalog/cd[price=10.90]/price
     87 
     88 选择一个以上的路径 
     89 使用Or操作数(|)就可以选择一个以上的路径。例如: 
     90 
     91 
     92 /catalog/cd/title | catalog/cd/artist
     93 
     94 选择所有title以及artist元素
     95 
     96 
     97 //title | //artist
     98 
     99 选择所有title以及artist以及price元素
    100 
    101 
    102 //title | //artist | //price
    103 
    104 选择属性 
    105 在XPath中,除了选择元素以外,也可以选择属性。属性都是以@开头。例如选择文件中所有叫做country的属性: 
    106 
    107 
    108 //@country
    109          
    110 选择所有含有country这个属性的cd元素:
    111 
    112 
    113 //cd[@country]
    114          
    115 以下语法选择出含有属性的所有cd元素
    116 
    117 
    118 //cd[@*]
    119          
    120 以下语法选择出country属性值为UK的cd元素
    121 
    122 
    123 //cd[@country='UK']

    链接:http://blog.csdn.net/whuarui2010/article/details/8012856

    http://www.cnblogs.com/timy/archive/2010/05/18/1738438.html

    http://www.jb51.net/article/35568.htm

    Xml文档添加节点和属性   转:http://www.cnblogs.com/shuang121/archive/2011/02/24/1963796.html

    在实际的应用开发中需要我们对xml进行添加节点和属性,动态的去完成,在这之前,先看看XmlNode和XmlElement之间的关系

    1、XmlElement继承XmlLinkedNode又继承XmlNode,所以XmlElement是XmlNode的子集,那么从继承的关系来说, 

         XmlNode的属性,XmlElement也可以使用。

    2、XmlNode是.Net提供的抽象类,不能直接实例化,只能通过XmlDocument的CreateNode方法来创建,但是

         XmlElement则不需要,可以直接实例化创建

    3、为节点添加属性的时候,可以直接通过XmlElement的SetAttribute来添加,也可以通过XmlNode的Attribute的add方法

         来添加,同样添加文本节点的时候也是如此

    4、XmlDocument是XmlNode的扩展类,包含了很多XmlNode没有的方法和属性,我们可以通过它将xml加载到内存中通过

        Dom来处理,也可以通过它来创建节点等

    下面就来看看如何添加节点和属性

    1、首先我们需要创建一个节点元素,创建的时候我们可以通过XmlDocument的CreateElement来创建,或者是通过

         XmlElement直接实例化,然后通过属性赋值,比如Name

    2、创建一个XmlNode,也就是说创建的节点需要放在什么位置,然后创建的节点加入该XmlNode后面就可以了(可以通过

        XmlNode的AppendChild方法来添加),比如加入根目录下面:XmlDocument.DocumentElement.PrependChild

        (XmlElement),如果是其他节点下,可以通过Xmldocument的SelectSingleNode("//Titles//Title")来获得XmlNode

    3、添加属性的时候,可以直接在创建XmlElment的时候,通过XmlElement的SetAttribute来为节点创建属性,或者是创建

         一个XmlAttribute实例:XmlAttribute  xmlArr=XmlDocument.CreateAttribute("属性值"),然后通过XmlNode的

        Attributes.add(XmlArribute)来添加

    下面来具体看几个例子吧

    1 <?xml version="1.0" encoding="utf-8"?>
    2 <Titles>
    3   <Title ID="21" Name="王六" />
    4   <Title ID="20" Name="王五" />
    5   <Title ID="19" Name="李四" />
    6   <Title ID="18" Name="张三" />
    7   <Title ID="16" Name="asdf" />
    8   <Title ID="17" Name="12" />
    9 </Titles>

    添加方法

     1 protected void Button3_Click(object sender, EventArgs e)
     2     {
     3 
     4         //加载xml文档
     5         XmlDocument doc = new XmlDocument();
     6         string path = Server.MapPath("~/Title.xml");
     7         doc.Load(path);
     8         //创建节点
     9         XmlElement xmlElement = doc.CreateElement("Title");
    10 
    11         //添加属性
    12         xmlElement.SetAttribute("ID", "21");
    13         xmlElement.SetAttribute("Name","王六");
    14         //将节点加入到指定的节点下
    15         XmlNode xml = doc.DocumentElement.PrependChild(xmlElement);
    16         doc.Save(path);
    17     }

    或者是

     1 protected void Button3_Click(object sender, EventArgs e)
     2     {
     3         XmlDocument doc = new XmlDocument();
     4         string path = Server.MapPath("~/Title.xml");
     5         doc.Load(path);
     6         //创建节点
     7         XmlElement xmlElement = doc.CreateElement("Title");
     8         ////将节点加入到指定的节点下
     9         XmlNode xmlTitle = doc.DocumentElement.PrependChild(xmlElement);
    10         //为该节点加入属性
    11         XmlAttribute xmlID = doc.CreateAttribute("ID");
    12         xmlID.Value = "22";
    13         xmlTitle.Attributes.Append(xmlID);
    14 
    15         XmlAttribute xmlName = doc.CreateAttribute("Name");
    16         xmlName.InnerText = "小三";
    17         xmlTitle.Attributes.Append(xmlName);
    18 
    19         doc.Save(path);
    20     }

    如果不需要创建节点,直接通过SelectSingleNode(string path)来获取XmlNode,然后再添加属性或者文本节点等,如下:

     1 protected void Button2_Click(object sender, EventArgs e)
     2     {
     3         XmlDocument doc = new XmlDocument();
     4         string path = Server.MapPath("~/XMLFile.xml");
     5         doc.Load(path);
     6         //创建一个book节点
     7         XmlNode xml = doc.SelectSingleNode("//TiTles//TiTle");
     8         XmlAttribute xmlAttribute = doc.CreateAttribute("ss");
     9         xmlAttribute.InnerText = "bb";
    10         xml.Attributes.Append(xmlAttribute);
    11         doc.Save(path);
    12     }

    大概过程就是

    1、通过XmlDocument加载xml文件到内存

    2、创建XmlElement节点(可以通过SetAttribute添加属性)

    3、创建和查找XmlNode以确保要放置的位置,将XmlElement添加到XmlNode中

    4、如果没有通过SetAttribute来添加属性,后面可以创建XmlArribute来完成属性的添加

    5、最后重新保存Xml:XmlDocument.save(xpath);

    转:http://www.cnblogs.com/shuang121/archive/2011/02/24/1963796.html

  • 相关阅读:
    php 三级连动及 php+ajax的调试方法
    ajax传值 乱码问题
    ajax传值给php
    php连接mssql pdo
    语法正确的情况下报错的原因
    Mina传递对象
    Mina小例子
    基于MINA构建简单高性能的NIO应用
    点与不规则图形关系判断
    Postman----基础使用篇(没有接口文档的情况下如何着手做接口测试)
  • 原文地址:https://www.cnblogs.com/sharpest/p/7720051.html
Copyright © 2011-2022 走看看