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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 初识公有云和私有云

    初识公有云和私有云最近刚开始接触云,粗浅记录下来自己的学习。第一个问题:什么是云计算?第二个问题:为什么要上云?第三个问题:公有云和私有云有什么区别,应该怎么选?云计算,是一种按使用量付费的模式,这种模式提供可用的、便捷的、按需的网络访问,进入可配置的计算资源共享池(资源包括网络,服务器,存储,应用软件,服务),这些资源能够被快速提供,只需投入很少的管理工作,或与服务供应商进行很少的交互。【百度百科】举例来讲,建立一个超级数据中心,提高算力,达到普通电脑无法企及的每秒10万亿次的运算能力,一般用户在付费后则可通过

    2022年6月25日
    26
  • idea切换到远程分支_git看不到远程分支

    idea切换到远程分支_git看不到远程分支描述最近项目建了分支,在并行开发,需要切换远程分支,在网上找了很多资料都不行。远程分支代码始终更新的是其他分支。解决方案话不多说,直接看图。操作上述之后,开始pull下远程代码,完毕后也可发现分支发生变化说明以上只在2016.1.3上验证。

    2022年9月21日
    8
  • BroadcastReceiver的生命周期

    BroadcastReceiver的生命周期

    2021年8月30日
    58
  • MySQL 日期格式化[通俗易懂]

    本文旨在以最快的速度,提供你需要的MySQL日期格式化方案。1.将时间格式化为YYYY-mm-ddHH:ii:ss格式我想你要搜的就是这个!!!哈哈哈SELECTDATE_FORMAT(NOW(),’%Y-%m-%d%H:%i:%s’)效果如图:2.获取当时时间SELECTNOW()效果如图:3.获取当时时间戳(10位长度)selectUNIX_TIMESTAMP(now())或SELECTUNIX_TIMESTAMP()效果如图:4.

    2022年4月13日
    58
  • 解决P2P传输瓶颈

    解决P2P传输瓶颈随着嵌入式技术这几年的迅速发展,在个人电脑平台上正显示出强大市场需求的流媒体技术,目前逐渐有向嵌入式平台转移的趋势。个人便携化、家电化的媒体消费需求,为这次平台的转移提供了市场契机。IPTV正是在这场消费革命中处在风口浪尖的焦点。业内大多认为IPTV蕴含了巨大的商业利益,但至今仍鲜有涉足者,其中原因之一是网络速度问题。本文介绍了对等网络技术,即点对点(P2P)技术,将其应用到IPTV网络传输中,可

    2022年7月16日
    11

发表回复

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

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