XML访问技术(1)--C++. .

来源:互联网 发布:万和热水器怎么样 知乎 编辑:程序博客网 时间:2024/05/16 14:06

1.      XML 文档操作

1.1.    加载一个XML文档

IXMLDOMDocumentPtr xmlDoc;

xmlDoc-> Load("Sample.xml");

1.2.    加载一个XML数据

char*strXml="<Employees><Employeeid=”12345”><Employee_ID>12345</Employee_ID><Name>ZhangBin</Name></Employee></Employees>"

xmlDoc-> LoadXML("Sample.xml");

1.3.    保存XML文档

xmlDoc->Save("Sample.xml");

 

2.      XML 数据的查询

最常见的XML数据类型有:Element、Attribute、Comment、Text。  

Element, 元素节点,指形如<Name>Tom<Name>的节点。它可以包括:Element、Text、Comment, ProcessingInstruction、CDATA、 and EntityReference。  

Attribute, 属性节点,指在<Employee id=”12345”>中的粗体部分。

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

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

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

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

IXMLDOMNodeListPtr

nodeList= xmlDoc->SelectNodes(“Company/Department/Employees/Employee”);

  或者

IXMLDOMNodeListPtr

nodeList = xmlDoc ->SelectNodes(“/Company/Department/Employees/Employee”);

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

 IXMLDOMNodePtr

xmlNode = xmlDoc ->SelectSingleNode(“/Company/Department/Employees/Employee”);

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

可使用类似于文件路径的相对路径的方式来查询XML的数据
IXMLDOMNodePtr  xmlNode = xmlDoc ->SelectSingleNode(“Company/Department”) ;

IXMLDOMNodePtr  xmlNode1 = xmlNode->SelectNode(“Employees/Employee”);

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

在使用不规则的层次文档时,由于不知道中间层次的元素名,可使用//符号来越过中间的节点,查询其子,孙或多层次下的其他所有元素。例如:
IXMLDOMNodeListPtr  nodeList = xmlDoc->SelectNodes(“Company//Employee”);

2.4.       查询属性(attribute)节点

 以上的各种方法都返回元素(element)节点(集),返回属性(attribute),只需要采用相应的方法,在属性名前加一个@符号即可,例如:
nodeList = xmlDoc->SelectNodes(“Company/Department/Employees/Employee/@id”);

nodeList = xmlDoc->SelectNodes(“Company//@id”);

2.5.       查询文本(Text)节点

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

xmlNode = xmlDoc->SelectSingleNode(“Company/Department/Deparmt_Name/text()”);

2.6.       查询特定条件的节点

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

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

  IXMLDOMNodePtr  xmlNode

= xmlDoc->SelectSingleNode(“Company/Department/Employees/Employee[@id=’10102’]”) ;

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

  IXMLDOMNodePtr  xmlNode = xmlDoc->SelectSingleNode(“Company/Department/Employees/Employee/Name[text()=’ZhangQi’]”) ;

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

  IXMLDOMNodePtr  xmlNode = xmlDoc->SelectSingleNode("Company/Department[Employees/Employee/@id='22345']/Department_Name");

2.7.       查询多重模式的节点

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

IXMLDOMNodeListPtr  nodeList =xmlDoc->SelectNodes(“Company/Department/Department_Name| Company/Department/Manager”);

2.8.       查询任意子节点

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

IXMLDOMNodeListPtr  nodeList = xmlDoc->SelectNodes(“Company/*/Manager);

  或者

IXMLDOMNodeListPtr  nodeList= xmlDoc->ChildNodes;

1.      XML数据的编辑

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

IXMLDOMNodePtr  attrNode;

attrNode = xmlDoc->CreateAttribute("id",Nothing) ;

attrNode->InnerXml = "101" ;

xmlNode->Attributes->Append(attrNode);

1.2.    删除一个元素的属性

xmlNode->Attributes->Remove(attrNode);

1.3.    增加一个子元素(Element)

IXMLDOMNodePtr  childNode;

childNode = xmlDoc->CreateElement(Nothing,"ID", Nothing) ;

childNode->InnerXml = "101" ;

xmlNode->AppendChild(childNode);

1.4.    删除一个子元素(Element)

xmlNode->RemoveChild(childNode);

1.5.    替换一个子元素(Element)

xmlNode->ReplaceChild(newChild,oldChild);

2.      参考数据

<?xmlversion="1.0" encoding="UTF-8"?>
  <Company>
   <Departmentid="101">
         <Department_Name>CaiWuBu</Department_Name>
         <Manager>ZhangBin</Manager>
                  <Employees>
                       <Employeeid="12345">
                            <Employee_ID>12345</Employee_ID>
                            <Name>ZhangBin</Name>
                            <Gender>male</Gender>
                       </Employee>
                       <Employeeid="10101">
                            <Employee_ID>10101</Employee_ID>
                            <Name>ZhangQI</Name>
                            <Gender>female</Gender>
                       </Employee>
                       <Employeeid="10102">
                            <Employee_ID>10102</Employee_ID>
                          <Name>Zhang Xia</Name>
                            <Gender>male</Gender>
                       </Employee>
                       <Employeeid="10201">
                            <Employee_ID>10201</Employee_ID>
                            <Name>ZhangChuang</Name>
                            <Gender>male</Gender>
                       </Employee>
                       <Employeeid="10202">
                           <Employee_ID>10202</Employee_ID>
                            <Name>ZhangJun</Name>
                            <Gender>male</Gender>
                       </Employee>
                  </Employees>
              </Department>
   <Departmentid="102">
         <Department_Name>KaiFaBu</Department_Name>
         <Manager>WangBin</Manager>
         <Employees>
              <Employeeid="22345">
                  <Employee_ID>22345</Employee_ID>
                  <Name>WangBin</Name>
                  <Gender>male</Gender>
              </Employee>
              <Employeeid="20101">
                  <Employee_ID>20101</Employee_ID>
                  <Name>WangQI</Name>
                  <Gender>female</Gender>
              </Employee>
              <Employeeid="20102">
                  <Employee_ID>20102</Employee_ID>
                  <Name>WangXia</Name>
                  <Gender>male</Gender>
              </Employee>
              <Employeeid="20201">
                  <Employee_ID>20201</Employee_ID>
                  <Name>WangChuang</Name>
                  <Gender>male</Gender>
              </Employee>
              <Employeeid="20202">
                  <Employee_ID>20201</Employee_ID>
                  <Name>WangJun</Name>
                  <Gender>male</Gender>
              </Employee>
         </Employees>
   </Department>
  </Company>
0 0