zoukankan      html  css  js  c++  java
  • EXPAT(XML解析库)

    一、简介

           expat是一个由C语言编写的XML解析库。James Clark创建了这个库,现在是制定XML标准的W3组织的技术leader。现在的版本是2.0。2.0开始就由Clark Cooper领导的开发组在sourceforge.net负责开发。

           expat是一个基于SAX模型的、非验证(默认,v1.2开始提供验证接口,需要用户手动处理)的轻量级XML解释器。目前XML的解析主要有两大模型:SAX和DOM。其中SAX(Simple API for XML)是基于事件的解析方法。基本工作原理是分析XML文档,通过触发事件来通知用户解析的结果。这种方式占用内存少,速度快,但用户程序相应得会比较复杂。而DOM(DocumentObject Model),则是一次性将整个XML文档进行分析,在内存中以树结构保存解析结果。同时,向用户提供一系列的接口来访问和编辑该树结构。这种方式占用内存大,速度往往慢于SAX,但可以给用户提供一个面向对象的访问接口,对用户更为友好。

          对于一个特定的XML文档而言,其正确性分为两个层次。首先是其格式应该符合XML的基本格式要求,比如第一行要有声明,标签的嵌套层次必须前后一致等等,符合这些要求的文件,就是一个合格的XML文件,称作well-formatted。但除此之外,一个XML文档因其内容的不同还必须在语义上符合相应的标准,这些标准由相应的DTD文件或者Schema文件来定义,符合了这些定义要求的XML文件,称作valid。

          因此,解析器也分为验证和非验证两种。是验证的会跟据XML文件中的声明,用相应的DTD文件对XML文件进行校验,检查它是否满足DTD文件的要求。非验证性的则忽略DTD文件,只要基本格式正确,就可以进行解析。常见XML解析库总结如下:

    image

    参考:http://www.xml.com/pub/a/1999/09/expat/index.html

    二、API

    expat-1.2.tar.gz下载

    三、实例

    示例1:example1.c

    #include <stdio.h>
    #include <stdlib.h>
    #include "xmlparse.h"
    
    void startElement (void *userData, const char *name, const char **atts)
    {
        int i;
        int *depthPtr = userData;
        for (i = 0; i < *depthPtr; i++)
            printf("	");
        puts (name);
    
        for (i = 0; atts[i]; i += 2)
        {
            printf("	%s='%s'", atts[i], atts[i + 1]);
        }
    
        printf("
    ");
        *depthPtr += 1;
    }
    
    void endElement (void *userData, const char *name)
    {
        int *depthPtr = userData;
        *depthPtr -= 1;
    }
    
    int main (int argc, char *argv[])
    {
        char buf[BUFSIZ];
        XML_Parser parser = XML_ParserCreate (NULL);
        int done;
        int depth = 0;
        FILE *fp;
    
        if (argc != 2)
        {
            printf("Usage: %s filename
    ", argv[0]);
            exit(0);
    
        }
        if ((fp = fopen(argv[1], "r")) == NULL)
        {
            printf("Can't open %s
    ", argv[1]);
            exit(1);
    
        }
    
        XML_SetUserData (parser, &depth);
        XML_SetElementHandler (parser, startElement, endElement);
        do
        {
            size_t len = fread (buf, 1, sizeof (buf), fp);
            // done = len < sizeof(buf);
            done = feof (fp);
            if (!XML_Parse (parser, buf, len, done))
            {
                fprintf (stderr, "%s at line %d
    ", XML_ErrorString (XML_GetErrorCode (parser)), XML_GetCurrentLineNumber (parser));
                return 1;
            }
        }
        while (!done);
        XML_ParserFree (parser);
        return 0;
    }

    编译

    gcc -g -o example1 example1.c -I/root/srcpkg/expat-1.2/xmlparse -L/root/srcpkg/expat-1.2/xmlparse -static -lexpat

    运行

    image

  • 相关阅读:
    「10.10」神炎皇(欧拉函数)·降雷皇(线段树,DP)·幻魔皇
    「10.8」simple「数学」·walk「树上直径」
    10.5「嘟嘟噜」·「天才绅士少女助手克里斯蒂娜」·「凤凰院凶真」
    csp-s模拟测试59(10.4)「Reverse」(set)·「Silhouette」(容斥)
    csp-s模拟测试58「Divisors」·「Market」·「Dash Speed」
    csp-s模拟测试57(10.2)「天空龙」·「巨神兵」·「太阳神」
    csp-s模拟测试56(10.2)Merchant「二分」·Equation「树状数组」
    csp-s模拟测试55(9.29)联「线段树」·赛「??」题「神仙DP」
    消防(树上直径)
    模拟测试65
  • 原文地址:https://www.cnblogs.com/274914765qq/p/4575438.html
Copyright © 2011-2022 走看看