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 xmlNode1 = xmlNode->SelectNode(“Employees/Employee”); 2.3.查询已知元素名的节点(集) 在使用不规则的层次文档时,由于不知道中间层次的元素名,可使用//符号来越过中间的节点,查询其子,孙或多层次下的其他所有元素。例如: 2.4.查询属性(attribute)节点 以上的各种方法都返回元素(element)节点(集),返回属性(attribute),只需要采用相应的方法,在属性名前加一个@符号即可,例如: 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>(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |