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

前端之家收集整理的这篇文章主要介绍了XML访问技术(1)--C++. .前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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.查询已知元素名的节点(集)

在使用不规则的层次文档时,由于不知道中间层次的元素名,可使用//符号来越过中间的节点,查询其子,孙或多层次下的其他所有元素。例如:
IXMLDOMNodeListPtrnodeList = 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.查询多重模式的节点

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

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

2.8.查询任意子节点

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

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

或者

IXMLDOMNodeListPtrnodeList= 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>

猜你在找的XML相关文章