--------------------------------------------------------------------------------------------------
l
xmlChar替代char,使用UTF-8编码的一字节字符串
l
xmlDoc包含由解析文档建立的树结构,xmlDocPtr是指向这个结构的指针。
xmlNodePtr和
xmlNode包含单一结点的结构,xmlNodePtr是指向这个结构的指针,它被用于遍历文档树。
xmlDocPtr doc;//定义文档指针
doc =
xmlNewDoc("1.0"); //以version = 1.0建立文档
doc =
xmlParseFile(docname); //解析文档,给文档指针赋值
doc =
xmlReadFile(docname,"GB2312",XML_PARSE_RECOVER); //以GB2312编码解析文档
xmlFreeDoc(doc); //释放解析文档时
获取到的内存
int nRel =
xmlSaveFile("-",doc); //将文档以默认方式存入一个
文件。
xmlSaveFormatFile(docname,doc,1); //保存
文件到磁盘,第一个参数是写入
文件的名,第二个参数是一个xmlDoc结构指针,第三个参数设定为1,保证在
输出上写入。
xmlSaveFormatFileEnc("-",encoding,1);//将文档以某种编码/格式存入一个
文件中。
xmlNodePtr cur;//定义结点指针
xmlDocSetRootElement(doc,rootnode);
cur =
xmlDocGetRootElement(doc); //
获取文档根结点
cur =
cur->xmlChildrenNode; //
获取结点的子结点
while (cur != NULL) {
……
cur = cur->next;
}
xmlChar *key;
key =
xmlNodeListGetString(doc,cur->xmlChildrenNode,1); //
获取文本结点的文本,需用其子结点
xmlFree(key); //释放xmlNodeListGetString为其返回的字符串分配的内存
xmlNewTextChild(cur,NULL,"keyword","123"); //为当前节点
添加一个新的子元素文本结点<keyword>123</keyword>,其中NULL是命名空间
rootnode =
xmlNewDocNode(doc,(const xmlChar*)"root",out);
rootnode =
xmlNewNode(NULL,(const xmlChar*)"root");
xmlNodePtr content =
xmlNewText((xmlChar *)"NODE CONTENT"); //注意不是xmlNewTextChild()
xmlAddChild(root_node,node);//为root_node
添加子结点node
xmlNewChild(root_node,(xmlChar *) "node1",(xmlChar *) szOut);//为root_node
添加子结点node1
xmlNodeSetContent(curNode,(xmlChar *) "content changed");
mlUnlinkNode(curNode); //将当前节点从文档中断链(unlink),这样本文档就不会再包含这个子节点
xmlFreeNode(curNode); //手动
删除断链节点的内存,若没有xmlDelNode或者xmlRemoveNode,使用此
函数
xmlAttrPtr newattr;
newattr =
xmlNewProp(newnode,"uri","123"); //为结点newnode
添加属性uri,
属性值为123
if (
xmlHasProp(curNode,(xmlChar *)"attribute")) //判断结点curNode是否具有
属性attribute
xmlAttrPtr attrPtr =
propNodePtr->properties; //
属性集是链表
xmlChar *uri;
uri =
xmlGetProp(cur,"uri"); //
获取属性值
xmlFree(uri); //释放内存
xmlSetProp(curNode,BAD_(xmlChar *)"attribute",(xmlChar *) "no"); //设置当前结点的attribute
属性的
属性值为no
xmlXPathContextPtr context;
context =
xmlXPathNewContext(doc); //
获取context指针
xmlXPathObjectPtr result;
result =
xmlXPathEvalExpression(xmlChar *xpath,context); //根据条件xpath以及context来进行
查询,条件格式:xmlChar *szXpath =(xmlChar *) ("
/root/node2[@attribute='yes']");
xmlXPathFreeContext(context); //释放context内存
if(
xmlXPathNodeSetIsEmpty(result->nodesetval)) //判断
查询后的结果是否为空
xmlNodeSetPtr nodeset;//创建节点集指针
nodeset =
result->nodesetval;//这个结点集对象包含在集合中的元素数目(nodeNr)及一个结点数组(nodeTab)。
for (i=0; i <
nodeset->nodeNr; i++)
keyword = xmlNodeListGetString(doc,nodeset->nodeTab[i]->xmlChildrenNode,1)
xmlXPathFreeObject(result); //释放内存
xmlCleanupParser();
xmlMalloc是动态分配内存的
函数;
xmlFree是配套的释放内存
函数;
xmlStrcmp是字符串比较
函数;
基本上xmlChar字符串相关
函数都在
xmlstring.h中定义;而动态内存分配
函数在
xmlmemory.
原文链接:https://www.f2er.com/xml/295022.html