C語言實現(xiàn)xml構(gòu)造解析器
更新時間:2016年07月03日 15:29:37 投稿:hebedich
本文給大家分享的是使用C語言來實現(xiàn)xml構(gòu)造解析器的方法和代碼,簡單易用,推薦給大家
純C實現(xiàn)xml構(gòu)造解析器,所有實現(xiàn)只有一個.c一個.h文件組成,簡單易用,易于擴展。
#include <string.h> #include <stdio.h> #include <stdlib.h> #include "sxml.h" #define LUA_SCRIPT "function fun()\n\ int a;\n\ a = 10;\n\ return a;\n\ end" int main() { sxml_file_info_t* info; char* tmp; const char* pstr; int line=1; char buff[128]={0}; sxml_doc_t* parser=NULL; sxml_doc_t* doc = sxml_doc_new("a.xml","1.0","GB2312"); sxml_node_t* node = sxml_node_new("root"); sxml_attr_t* attr = sxml_attr_new("age","25"); sxml_node_t* subnode = sxml_node_new("score"); sxml_node_t* rawdata = sxml_rawdata_new(NULL,"hello world!",strlen("hello world!")); sxml_node_t* rawdata2 = sxml_rawdata_new(NULL,"hello world!",strlen("hello world!")); sxml_node_t* rawdata3 = sxml_rawdata_new(NULL,"hello world!",strlen("hello world!")); sxml_node_t* rawdata4 = sxml_rawdata_new("raw","rawdata",strlen("rawdata")); sxml_node_t* rawdata5 = sxml_rawdata_new("lua",LUA_SCRIPT,strlen(LUA_SCRIPT)); sxml_node_t* innertext = sxml_innertext_new("內(nèi)部字符串"); sxml_node_t* comment = sxml_comment_new("注釋"); sxml_node_t* empty = sxml_empty_new("empty"); sxml_add_attr2node(node,attr); attr = sxml_attr_new("sex","man"); sxml_add_attr2node(node,attr); attr = sxml_attr_new("語文","95"); sxml_add_attr2node(subnode,attr); attr = sxml_attr_new("數(shù)學","100"); sxml_add_attr2node(subnode,attr); attr = sxml_attr_new("英語","98"); sxml_add_attr2node(subnode,attr); sxml_add_subnode2node(node,subnode); sxml_add_subnode2node(node,rawdata); sxml_add_subnode2node(node,rawdata2); sxml_add_subnode2node(node,rawdata3); sxml_add_subnode2node(node,rawdata4); sxml_add_subnode2node(node,rawdata5); sxml_add_subnode2node(node,innertext); sxml_add_subnode2node(node,comment); sxml_add_subnode2node(node,empty); sxml_add_node2doc(doc,node); //printf("%s\n",sxml_doc_print_buffered(doc,16)); tmp = sxml_doc_print(doc); pstr = tmp; printf("%s\n", tmp); while((pstr = skip_line(pstr)))line++; printf("\n\n%d\n\n", line); //printf("\n\n%s\n\n",check_skip("<?xml version=\"1.0\" encoding=\"GB2312\"?>","<?xml version=\\\"")?"YES":"NO"); //copy_until(buff,"<?xml version=\"1.0\" encoding=\"GB2312\"?>","\" "); //printf("\n\n%s\n\n",buff); //sxml_save(doc); sxml_doc_free(doc); doc = NULL; free(tmp); //printf("aaaa...................\n"); //getchar(); parser = sxml_parse("a.xml"); //tmp = sxml_doc_print(parser);//有問題,內(nèi)存越界 tmp = sxml_doc_print_buffered(parser,16); printf("%s\n", tmp); free(tmp); sxml_save2file(parser,"b.xml"); sxml_doc_free(parser); return 0; }
相關文章
C++容器適配與棧的實現(xiàn)及dequeque和優(yōu)先級詳解
這篇文章主要介紹了C++容器適配與棧的實現(xiàn)及dequeque和優(yōu)先級,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧2022-10-10C語言數(shù)據(jù)在內(nèi)存中的存儲流程深入分析
使用編程語言進行編程時,需要用到各種變量來存儲各種信息。變量保留的是它所存儲的值的內(nèi)存位置。這意味著,當您創(chuàng)建一個變量時,就會在內(nèi)存中保留一些空間。您可能需要存儲各種數(shù)據(jù)類型的信息,操作系統(tǒng)會根據(jù)變量的數(shù)據(jù)類型,來分配內(nèi)存和決定在保留內(nèi)存中存儲什么2022-10-10C++最短路徑Dijkstra算法的分析與具體實現(xiàn)詳解
經(jīng)典的求解最短路徑算法有這么幾種:廣度優(yōu)先算法、Dijkstra算法、Floyd算法。本文是對?Dijkstra算法的總結(jié),該算法適用于帶權(quán)有向圖,可求出起始頂點到其他任意頂點的最小代價以及對應路徑,希望對大家有所幫助2023-03-03Visual?Studio?2022?安裝低版本?.Net?Framework的圖文教程
這篇文章主要介紹了Visual?Studio?2022?如何安裝低版本的?.Net?Framework,首先打開?Visual?Studio?Installer?可以看到vs2022?只支持安裝4.6及以上的版本,那么該如何安裝4.6以下的版本,下面將詳細介紹,需要的朋友可以參考下2022-09-09c與c++之間的相互調(diào)用及函數(shù)區(qū)別示例詳解
這篇文章主要為大家介紹了c與c++相互調(diào)用的使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06用C語言實現(xiàn)從文本文件中讀取數(shù)據(jù)后進行排序的功能
這是一個十分可靠的程序,這個程序的查錯能力非常強悍。程序包含了文件操作,歸并排序和字符串輸入等多種技術(shù)。對大家學習C語言很有幫助,有需要的一起來看看。2016-08-08