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. php代码审计8审计文件上传漏洞

    文件上传漏洞是指用户上传了一个可执行的脚步文件,并通过此脚本文件获得了执行服务器端命令的能力,这种攻击方式是最直接和有效的,文件上传本身是没问题的,有问题的是文件上传后,服务器怎么处理,解释文件,通过 ...

  2. luoguP2982 [USACO10FEB]慢下来Slowing down

    https://www.luogu.org/problemnew/show/P2982 这题你写个树剖当然可以做,但是我们还有一种更简单的方法,使用 dfs 序 + 树状数组即可 考虑一只牛到了自己的 ...

  3. 冒泡排序 思想 JAVA实现

    已知一个数组78.75.91.36.72.94.43.64.93.46,使用冒泡排序将此数组有序. 冒泡排序是一个运行时间为O(N²)的排序算法. 算法思想:(已从小到大为例) 78.75.91.36 ...

  4. ASP.Net一般处理程序Session用法

    1.在aspx和aspx.cs中,都是以 Session["type"]="aaa" 和 string aaa=Session["type" ...

  5. JS 节点的属性 与 元素

    节点的属性{     nodeType 是节点的类型:     nodeNam 是节点的名字     nodeValue 节点的值 }可以用节点.属性 取得三个属性的值 节点.nodeType 出来的 ...

  6. 精通 WPF UI Virtualization (提升 OEA 框架中 TreeGrid 控件的性能)

    原文:精通 WPF UI Virtualization (提升 OEA 框架中 TreeGrid 控件的性能) 本篇博客主要说明如何使用 UI Virtualization(以下简称为 UIV) 来提 ...

  7. C++_函数1-编程的基本模块函数

    以下是<C++ Primer Plus>中第七章的内容: 使用C++函数的3个步骤: 提供函数定义 提供函数原型 调用函数 7.1.1 定义函数 函数分成两类:没有返回值的函数.有返回值的 ...

  8. xml转换csv

    /// <summary> /// xml文件转换为CSV /// </summary> /// <param name="fileName"> ...

  9. Week 5: Object Oriented Programming 9. Classes and Inheritance Exercise: int set

    class intSet(object): """An intSet is a set of integers The value is represented by a ...

  10. (找到最大的整数k使得n! % s^k ==0) (求n!在b进制下末尾0的个数) (区间满足个数)

    题目:https://codeforces.com/contest/1114/problem/C 将b分解为若干素数乘积,记录每个素数含多少次方 b = p1^y1·p2^y2·...·pm^ym. ...