C语言xml文件存储数据文件(一)

C语言xml文件存储数据文件(一)————————————————版权声明:本文为CSDN博主「jack8126」的原创文章,遵循CC4.0BY-SA版权协议,转载请附上原文出处链接及本声明。原文链接:https://blog.csdn.net/jack8126/article/details/117004179本文,摘抄的,未验证过,纯属保存留用,请看原作者。c语言读取xml配置文件c语言要实现读取xml配置文件的功能。需要先编译libxml2库。1、编译libxml2库libxml2库从网络下载得到,这里下载的文件是:

大家好,又见面了,我是你们的朋友全栈君。

————————————————
版权声明:本文为CSDN博主「jack8126」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/jack8126/article/details/117004179

本文,摘抄的,未验证过,纯属保存留用,请看原作者。

c语言读取xml配置文件
c语言要实现读取xml配置文件的功能。需要先编译libxml2库。

1、编译libxml2库
libxml2库从网络下载得到,这里下载的文件是:libxml2-sources-2.9.9.tar.gz

1.1、将libxml2文件拷贝到ubuntu系统下并解压
切换到libxml2库存在的路径下。

执行解压缩命令:
tar -zxvf libxml2-sources-2.9.9.tar.gz
在这里插入图片描述
解压之后并切换到libxml2库路径下。
在这里插入图片描述
1.2、配置libxml2库
执行配置命令
./configure –prefix=/mnt/work/test/test/c/output
在这里插入图片描述
1.3、编译libxml2库
执行编译命令:make
在这里插入图片描述
编译过程中出现出错
libxml.c:14:20: fatal error: Python.h: No such file or directory

需要安装python,执行命令:
sudo apt-get install python-dev
在这里插入图片描述
安装完python-dev之后,再次编译成功。
执行make install执行安装在这里插入图片描述
安装完成之后,查看output路径下,增加了相关的文件。
在这里插入图片描述

2、xml配置文件
xml配置文件如下:

<?xml version="1.0" encoding="UTF-8"?>
<bmp_para>
  <para id="1">
     <width>1920</width>
     <height>1080</height>
     <bit>3</bit>
     <blue>0</blue>
     <green>0</green>
     <red>255</red>     
  </para>
</bmp_para>

3、c代码读取xml文件
c实现代码如下:

/******************************************************* * file:testReadXml.c * date:2021-05-18 * version:1.0.0.1 * author:jack8126 * description: read para from xml file *******************************************************/
#include <stdio.h>
#include <assert.h>
 
#include <libxml/xmlmemory.h>
#include <libxml/parser.h>
 
#define DEFAULT_XML_FILE "test.xml"
 
//解析para字段,提取出width,height,bit,red,green,blue参数
static int parse_bmp(xmlDocPtr doc, xmlNodePtr cur)
{ 
   
    assert(doc || cur);
    xmlChar *key;
 
    cur = cur->xmlChildrenNode;
    while (cur != NULL) { 
   
	    //获取width
	    if ((!xmlStrcmp(cur->name, (const xmlChar *)"width"))) { 
   
	        key = xmlNodeListGetString(doc, cur->xmlChildrenNode, 1);
	        printf("width: %s\r\n", key);
	        xmlFree(key);
	    }
	    //获取height
	    if ((!xmlStrcmp(cur->name, (const xmlChar *)"height"))) { 
   
	        key = xmlNodeListGetString(doc, cur->xmlChildrenNode, 1);
	        printf("height: %s\r\n", key);
	        xmlFree(key);
	    }
	    //获取bit
	    if ((!xmlStrcmp(cur->name, (const xmlChar *)"bit"))) { 
   
	        key = xmlNodeListGetString(doc, cur->xmlChildrenNode, 1);
	        printf("bit: %s\r\n", key);
	        xmlFree(key);
	    }
	    //获取 blue
	    if ((!xmlStrcmp(cur->name, (const xmlChar *)"blue"))) { 
   
	        key = xmlNodeListGetString(doc, cur->xmlChildrenNode, 1);
	        printf("blue: %s\r\n", key);
	        xmlFree(key);
	    }
	    //获取 green
	    if ((!xmlStrcmp(cur->name, (const xmlChar *)"green"))) { 
   
	        key = xmlNodeListGetString(doc, cur->xmlChildrenNode, 1);
	        printf("green: %s\r\n", key);
	        xmlFree(key);
	    }
	    //获取 red
	    if ((!xmlStrcmp(cur->name, (const xmlChar *)"red"))) { 
   
	        key = xmlNodeListGetString(doc, cur->xmlChildrenNode, 1);
	        printf("red: %s\r\n", key);
	        xmlFree(key);
	    }

	    cur = cur->next;
    }
    return 0;
}
 
static int parse_para(const char *file_name)
{ 
   
	assert(file_name);

	xmlDocPtr doc;   //xml整个文档的树形结构
	xmlNodePtr cur;  //xml节点
	xmlChar *id;     //phone id

	//获取树形结构
	doc = xmlParseFile(file_name);
	if (doc == NULL) { 
   
		fprintf(stderr, "Failed to parse xml file:%s\n", file_name);
		goto FAILED;
	}

	//获取根节点
	cur = xmlDocGetRootElement(doc);
	if (cur == NULL) { 
   
		fprintf(stderr, "Root is empty.\n");
		goto FAILED;
	}

	if ((xmlStrcmp(cur->name, (const xmlChar *)"bmp_para"))) { 
   
		fprintf(stderr, "The root is not bmp_para.\n");
		goto FAILED;
	}

	//遍历处理根节点的每一个子节点
	cur = cur->xmlChildrenNode;
	while (cur != NULL) { 
   
		if ((!xmlStrcmp(cur->name, (const xmlChar *)"para"))) { 
   
			id = xmlGetProp(cur, "id");
			printf("id:%s\r\n",id);
			parse_bmp(doc, cur);
		}
		cur = cur->next;
	}
	xmlFreeDoc(doc);
	return 0;
	FAILED:
	if (doc) { 
   
		xmlFreeDoc(doc);
	}
	return -1;
}
 
int main(int argc, char*argv[])
{ 
   
    char cFileNameRead[64] = { 
   0}; 

	if(argc < 2)
	{ 
   
		printf("please input like this:\r\n");
		printf("./testReadXml.bin test.xml \r\n");
		printf("test.xml --------------- input xml file \r\n");
		return -1;
	}

    sprintf(cFileNameRead,"%s",argv[1]);
	printf("cFileNameRead=%s\r\n",cFileNameRead);

	if (parse_para(cFileNameRead) != 0) { 
   
		fprintf(stderr, "Failed to parse bmp para.\n");
		return -1;
	}

	return 0;
}

4、编译程序
执行编译命令
gcc -g testReadXml.c -o testReadXml.bin -I /mnt/work/test/test/c/output/include/libxml2/ -L /mnt/work/test/test/c/output//lib/ -lxml2
在这里插入图片描述
gcc编译时,需要制定libxml2库的位置和头文件的位置。

5、执行程序
执行命令如下:
./testReadXml.bin test.xml

执行效果如下:
在这里插入图片描述
如上图打印信息,可以通过libxml读取到test.xml文件中的关于bmp的宽高和红绿蓝参数。

参考链接:
https://blog.csdn.net/qingzhuyuxian/article/details/82596386
————————————————
版权声明:本文为CSDN博主「jack8126」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/jack8126/article/details/117004179

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/157864.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月12日 下午9:46
下一篇 2022年7月12日 下午9:46


相关推荐

  • css虚线圆环 和实线圆环

    css虚线圆环 和实线圆环虚线圆环 dashed 为破折号间隔 dotted 为点间隔 border radius 50px width 100px height 100px border 1pxdashedred 实线圆环 border radius 50px width 100px height 100px border 1pxsolidred 菜鸟网站可以在线运行 https www runoob com try try php filename trycss3 border radius

    2026年3月17日
    2
  • java学习–while和if的区别

    java学习–while和if的区别这几天接触了多线程 发现 while 和 if 还是有区别的 以前想当然认为都是判断条件的 while 循环语句 可以执行多次 if 是条件语句 只是单次执行 while 表达式 nbsp 语句组 计算表达式 若为真 执行语句 并重复该过程 直到为假时 执行下一条语句 nbsp 例如 while k0 i 表示只要 k0 就执行 i 直到等到 k 比如多线程中的语句 while flag nbsp

    2026年3月16日
    2
  • K8S架构详解

    K8S架构详解

    2021年5月29日
    102
  • LR模型的原理和公式推导

    LR模型的原理和公式推导介绍 Logistic 回归算法 名字虽带有回归 但其实是一个分类模型 输出 Y 1 的对数几率是由输入 x 的线性函数表示的模型 直接对分类的可能性进行建模 并不是直接对分类的结果 0 或者 1 进行建模 假设一个样本属于正样本的概率为 p 则 LR 模型是在线性回归的基础上 把特征进行线性组合 再把组合的结果通过一层 sigmoid 函数映射成结果是 1 或是 0 的概率 逻辑斯蒂回归模型的特点

    2026年3月18日
    2
  • 微创业平台

    一种专为大学生创业服务的平台。主旨是,让大学生创业创新,在某种比较简单,比较容易的环境里进行。让大学生创业创新,不要太多的风险,比较容易达成创业目标。云电话,一种5G新电话。特别适合大学生微创业,更需要大学生微创新。将云电话平台,建设成湖铁微创业平台,是深圳云电话平台,与湖铁职院创新创业学院,合作打造的专为湖铁职院大学生,创新创业服务的平台。建设好湖铁微创业平台,具有重大的社会意义。√成功示范作用。先在创新创业学院,打造标杆试点MVP。√便…

    2022年4月4日
    90
  • OpenClaw(Clawdbot)一键接入QQ,2分钟搞定,太简单了!

    OpenClaw(Clawdbot)一键接入QQ,2分钟搞定,太简单了!

    2026年3月13日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号