Libxml2 学习


1、概要

libxml 是一个实现操作XML数据功能的开源C语言库。

2、windows下使用libxml

ftp://gd.tuwien.ac.at/pub/libxml/win32 下载 libxml2  iconv  libz  将其放到某个目录下
配置VS 项目中添加头文件和  三个的都文件都需要

3、libxml使用

3.1 libxml 生成xml文件

    主要通过函数 xmlNewDoc xmlNewNode xmlDocSetRootElement xmlNewTextChild xmlSaveFormatFileEnc 来实现
    如下代码:
    
static int Test_New(char* szFile)
{
    xmlDocPtr    doc = NULL;       //
    xmlNodePtr    rootNode = NULL;
    xmlNodePtr    node = NULL;
    xmlNodePtr    node1 = NULL;
    doc = xmlNewDoc(BAD_CAST "1.0");
    rootNode = xmlNewNode(NULL, BAD_CAST "root");
    xmlDocSetRootElement(doc, rootNode);
    node = xmlNewTextChild(rootNode, NULL, BAD_CAST "student", NULL);
    xmlNewTextChild(node, NULL, BAD_CAST "name", BAD_CAST "zhangsan");
    xmlNewTextChild(node, NULL, BAD_CAST "age", BAD_CAST "25");
    xmlNewTextChild(node, NULL, BAD_CAST "sex", BAD_CAST "labc");
    xmlNewChild(rootNode, NULL, BAD_CAST "node1", BAD_CAST "node1_test&");
    xmlNewTextChild(rootNode, NULL, BAD_CAST "node2", BAD_CAST "node2_test&");
    node = xmlNewTextChild(rootNode, NULL, BAD_CAST "node3", BAD_CAST "node3test");
    xmlNewProp(node, BAD_CAST "color", BAD_CAST "0A");
    xmlNewProp(node, BAD_CAST "attr", BAD_CAST "123");
    node = xmlNewNode(NULL, BAD_CAST "node4");
    node1 = xmlNewText(BAD_CAST "node4T<");
    xmlAddChild(rootNode, node);
    xmlAddChild(node, node1);
    xmlSaveFormatFileEnc(szFile, doc, "UTF-8", 1);
    xmlFreeDoc(doc);
    return 0;

}  


结果:

 需要几点注意的地方:
(1)这里一定注意 xmlNewDoc 中固定为1.0 千万不要写其他的,否则会出错。之前写成了V1.0 被折腾了半天。
(2)xmlNewTextChild xmlNewChild 都可以创建子节点,但是他们还是有区别的,主要区别在于如果content中包含了& < > 等符号时,使用xmlNewChild 会出错,而  xmlNewTextChild  不会出错,这些保留符号会被自动转义,所以推荐使用 xmlNewTextChild 
(3)一共提供了3中增加子节点的方法,注意 xmlNewText 也会转义特殊字符。


3.2 libxml 遍历xml文件的node


static int print_child(xmlNodePtr node)
{
    if (node == NULL)
    {
        return 1;
    }
    if (node->type == XML_ELEMENT_NODE)
    {
        printf("<%s>\n", node->name);
    }
    for (node = node->children; node != NULL; node = node->next)
    {
        print_child(node);
    }
    return 0;

}  

static int Test_AnalysisFile(char* szFile)
{
    xmlDocPtr    doc = NULL;       //文件指针
    xmlNodePtr    root = NULL;
    
    doc = xmlReadFile(szFile, "UTF-8", XML_PARSE_NOBLANKS);
    if (doc == NULL)
    {
        printf("xmlReadFile error %s\n", xmlGetLastError()->message);
        return 1;
    }
    root = xmlDocGetRootElement(doc);
    if (root == NULL)
    {
        xmlFreeDoc(doc);
        return 0;
    }
    print_child(root);
    xmlFreeDoc(doc);
    return 0;

}  


通过 xmlReadFile 函数来实现解析xml文件。
注意,这里node->children  也可以用宏定义 node->xmlChildrenNode  

3.3 转换xml Node为字符串

static int Test_ToString(char* szFile)
{
    xmlDocPtr        doc = NULL;       //文件指针
    xmlNodePtr        root = NULL;
    xmlBufferPtr    nodeBuffer;
    char            szBuf[1024] = { 0 };
    doc = xmlReadFile(szFile, "UTF-8", XML_PARSE_NOBLANKS);
    if (doc == NULL)
    {
        printf("xmlReadFile error %s\n", xmlGetLastError()->message);
        return 1;
    }
    root = xmlDocGetRootElement(doc);
    if (root == NULL)
    {
        xmlFreeDoc(doc);
        return 0;
    }
    
    nodeBuffer = xmlBufferCreate();
    xmlNodeDump(nodeBuffer, doc, root, 0, 1);
    snprintf(szBuf, sizeof(szBuf), (char*)nodeBuffer->content);
    xmlBufferFree(nodeBuffer);
    xmlFreeDoc(doc);
    printf("%s\n", szBuf);
    return 0;

}  


这里,通过xmlNodeDump来实现转换为字符串,结果如下
 
注意这里 xmlNodeDump(nodeBuffer, doc, root, 0, 1); 函数最后一个参数 如果为0的话则会去掉空白符如下

 







Libxml2 学习的更多相关文章

  1. iOS 阶段学习第23天笔记(XML数据格式介绍)

    iOS学习(OC语言)知识点整理 一.XML数据格式介绍 1)概念:xml是extensible markup language扩展的标记语言,一般用来表示.传输和存储数据 2)xml与json目前使 ...

  2. Android源码-学习随笔

    在线代码网站1:http://grepcode.com/project/repository.grepcode.com/java/ext/com.google.android/android/ 书籍: ...

  3. IOS学习笔记25—HTTP操作之ASIHTTPRequest

    IOS学习笔记25—HTTP操作之ASIHTTPRequest 分类: iOS2012-08-12 10:04 7734人阅读 评论(3) 收藏 举报 iosios5网络wrapper框架新浪微博 A ...

  4. 值得学习的C语言开源项目

    值得学习的C语言开源项目   - 1. Webbench Webbench是一个在linux下使用的非常简单的网站压测工具.它使用fork()模拟多个客户端同时访问我们设定的URL,测试网站在压力下工 ...

  5. 关于学习是UIWebView的一些思考

    前几天因为数据中加载有html语言的数据,关于html语言和UIWebView,有一些纠结,经过几天的研究,也有了一些自己的简单的见解.          我有两个页面需要加载html语言(注意,这里 ...

  6. XML格式以及相关libxml库学习

    本文参考 XML文件格式语法以及DTD,摘除其中自己认为必要的知识点,在此记录如下. 先给出一个xml的实例文件, <?xml version="1.0" encoding= ...

  7. IOS学习:常用第三方库(GDataXMLNode:xml解析库)

    IOS学习:常用第三方库(GDataXMLNode:xml解析库) 解析 XML 通常有两种方式,DOM 和 SAX: DOM解析XML时,读入整个XML文档并构建一个驻留内存的树结构(节点树),通过 ...

  8. 值得学习的C/C++开源框架(转)

    值得学习的C语言开源项目 - 1. Webbench Webbench是一个在linux下使用的非常简单的网站压测工具.它使用fork()模拟多个客户端同时访问我们设定的URL,测试网站在压力下工作的 ...

  9. #0 scrapy爬虫学习中遇到的坑记录

    python 基础学习中对于scrapy的使用遇到了一些问题. 首先进行的是对Amazon.cn的检索结果页进行爬取,很顺利,无碍. 下一个目标是对baidu的搜索结果进行爬取 1,反爬虫 1.1 我 ...

随机推荐

  1. Not all processes could be identified, non-owned process info will not be shown, you would have to be root to see it all.

    分析:还是权限问题,所以给他加上权限就可以了!! 解决:chmod +s /bin/netstat

  2. Qt 学习之路 2(32):贪吃蛇游戏(2)

    Qt 学习之路 2(32):贪吃蛇游戏(2) 豆子 2012年12月27日 Qt 学习之路 2 55条评论 下面我们继续上一章的内容.在上一章中,我们已经完成了地图的设计,当然是相当简单的.在我们的游 ...

  3. python之读取文件的测试数据

    假设我们有一个叫testdata.txt的文件,现在在这个文件里面有测试数据,我们怎么利用前2小章学习的知识,读取测试数据呢? 测试数据如下: url:https://www.cnblogs.com/ ...

  4. rest-assured之获取响应数据(Getting Response Data)

    我们使用rest-assured可以获得响应内容,比如:我们发起一个get请求 get("/lotto") 并且获得响应内容,我们有多种方式可以实现: // 通过流的方式获得响应内 ...

  5. Covering(矩阵快速幂)

    Bob's school has a big playground, boys and girls always play games here after school.  To protect b ...

  6. HDU6470 ()矩阵快速幂

    http://acm.hdu.edu.cn/showproblem.php?pid=6470 题意:f[n] = f[n-1] + f[n-2]*2 + n^3; f[1] =1 ; f[2] = 2 ...

  7. window7下karma 报 The header content contains invalid characters BUG

    打开你的依赖node_modules\karma\node_modules\connect\lib\patch.js 将里面的setHeader方法改成下面这样,干掉序列化日期时出现的中文 res.s ...

  8. AtCoder Beginner Contest 113 A

    A - Discount Fare Time limit : 2sec / Memory limit : 1024MB Score: 100 points Problem Statement Ther ...

  9. javascript的Astar版 寻路算法

    去年做一个模仿保卫萝卜的塔防游戏的时候,自己写的,游戏框架用的是coco2d-html5 实现原理可以参考 http://www.cnblogs.com/technology/archive/2011 ...

  10. Tesorflow-自动编码器(AutoEncoder)

    直接附上代码: import numpy as np import sklearn.preprocessing as prep import tensorflow as tf from tensorf ...