欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言開源庫iniparser解析ini文件的方法

 更新時間:2024年04月26日 10:49:39   作者:大草原的小灰灰  
INI(Initialization?File)文件是一種簡單直觀的數(shù)據(jù)存儲格式,常用于配置應用程序的初始化設置,使用?iniparser?庫的應用程序可以很方便地讀取和解析INI文件中的配置信息,大大簡化了對配置文件的處理工作,降低了程序的開發(fā)復雜度,感興趣的的朋友跟隨小編一起看看吧

1 ini文件介紹

  • INI(Initialization File)文件是一種簡單直觀的數(shù)據(jù)存儲格式,常用于配置應用程序的初始化設置。這種文件通常包含若干個節(jié)(section)和鍵值對(key-value pairs)。INI文件的每一部分都是自描述性的,易于閱讀和編輯,使得非程序員也能輕易理解并修改配置參數(shù)。
  • INI文件因其簡單易用性而在許多編程語言中廣泛應用,尤其是在Windows操作系統(tǒng)中,很多應用程序都采用INI文件作為配置文件。當然,隨著XML、JSON等更豐富、更結構化的數(shù)據(jù)交換格式的普及,INI文件在現(xiàn)代應用程序中的使用相對減少,但在一些輕量級應用或對啟動速度有較高要求的情況下,仍然是一種常見且實用的配置文件格式。

2 ini文件結構

  • 節(jié)(Section):INI文件中的各個部分通過方括號 [] 包裹的名稱來定義,例如 [Section1]。每個節(jié)可以包含多個鍵值對。
  • 鍵值對(Key-Value Pairs):鍵和值之間用等號 = 分隔,如 key1=value1。鍵通常是描述性質(zhì)的字符串,而值則可以是字符串、數(shù)字或其他類型的數(shù)據(jù)。
  • 注釋:注釋行以分號 ; 開始,直到行尾都被視為注釋內(nèi)容,不會被程序解析。
  • 多行值:某些INI解析器允許值跨越多行,通常通過在行尾添加反斜杠 \ 來延續(xù)到下一行

iniparser

iniparser 是一個開源的 C 語言庫,用于解析和操作 INI 格式的配置文件
使用 iniparser 庫的應用程序可以很方便地讀取和解析INI文件中的配置信息,大大簡化了對配置文件的處理工作,降低了程序的開發(fā)復雜度。由于其開源屬性,開發(fā)者可以根據(jù)自己的需求自由使用、研究和改進該庫。

3 相關API

3.1 加載ini文件

  /*
   *  @brief  從ini格式的配置文件中加載數(shù)據(jù)
   *  @param  [IN]  ininame  要打開的ini格式文件            
   *  @return != NULL 返回一個指向dictionary結構的指針
   *          == NULL 加載ini文件失敗
  */
  dictionary * iniparser_load(const char *ininame);

3.2 獲取鍵值

  /*
   *  @brief  獲取指定鍵(key)對應的字符串類型的值
   *  @param  [IN]  d  dictionary結構的指針   
   *  @param  [IN]  key  要查找的鍵,通常格式為 "section:key",表示要獲取哪個節(jié)(section)下的哪一項(key)的值。
   *  @param  [IN]  def  當鍵不存在或者其值不是字符串時的默認返回值。如果沒有找到對應鍵,函數(shù)將返回此默認值。    
   *  @return 如果找到了相應的鍵,返回鍵值對應字符串
   * 			如果沒有找到匹配的鍵,返回def指定的字符串值
  */
  const char * iniparser_getstring(const dictionary *d, const char *key, const char *def);
  /*
  *  @brief  獲取指定鍵(key)對應的整數(shù)值
  *  @param  [IN]  d  dictionary結構的指針   
  *  @param  [IN]  key  要查找的鍵,通常格式為 "section:key",表示要獲取哪個節(jié)(section)下的哪一項(key)的值。
  *  @param  [IN]  notfound  當鍵不存在或者其值不能被轉換為整數(shù)時,函數(shù)將返回這個默認值。   
  *  @return 如果找到了相應的鍵,并且其值可以被成功轉換為整數(shù),則返回該整數(shù)值。
  *		   如果沒有找到匹配的鍵,或者該鍵對應的值無法轉換為整數(shù),則返回 notfound 參數(shù)提供的默認值。
  */
  int iniparser_getint(const dictionary * d, const char * key, int notfound);
  /*
  *  @brief  獲取指定鍵(key)對應的浮點型值
  *  @param  [IN]  d  dictionary結構的指針   
  *  @param  [IN]  key  要查找的鍵,通常格式為 "section:key",表示要獲取哪個節(jié)(section)下的哪一項(key)的值。
  *  @param  [IN]  notfound  當鍵不存在或者其值無法轉換為雙精度浮點數(shù)時,函數(shù)返回的默認值。
  *  @return 如果找到了相應的鍵,并且其值能成功轉換為一個雙精度浮點數(shù),則返回該浮點數(shù)。
  *		   如果沒有找到匹配的鍵,或者鍵的值不能被解釋為一個有效的雙精度浮點數(shù),則返回 notfound 參數(shù)所提供的默認值。
  */
  double iniparser_getdouble(const dictionary *d, const char *key, double notfound);

3.3 設置鍵值

  /*
  *  @brief  設置或修改 ini  配置文件中某個鍵值對
  *  @param  [IN]  d  dictionary結構的指針   
  *  @param  [IN]  entry  字符串形式的鍵值對標識符,格式通常是 "section:key",表明您要在哪個節(jié)(section)下的哪個鍵(key)上設置或修改值(val)。
  *						key值存在則修改對應val,key值不存在則會新增
  *  @param  [IN]  val: 要設置的新值,作為字符串傳遞。
  *  @return 返回0表示設置成功
  */
  int iniparser_set(dictionary *ini, const char *entry, const char *val);

3.4 移除鍵值

  /*
  *  @brief  移除 ini 配置文件中某個鍵值對
  *  @param  [IN]  d  dictionary結構的指針   
  *  @param  [IN]  entry  字符串形式的鍵名,包括可選的部分名稱(section)和鍵(key)
  *					     如果不指定key,則會移除整個section
  */
  void iniparser_unset(ini, const char *entry);

3.5 判斷鍵是否存在

  /*
  *  @brief  判斷 ini 配置文件是否存在某個鍵值
  *  @param  [IN]  d  dictionary結構的指針   
  *  @param  [IN]  entry  字符串形式的鍵值對標識符,格式通常是 "section:key"
  *  @return 返回1表示存在,返回0表示不存在
  */
  int iniparser_find_entry(const dictionary *ini, const char *entry);

3.6 獲取section個數(shù)

  /*
  *  @brief  獲取ini配置文件中section的數(shù)量
  *  @param  [IN]  d  dictionary結構的指針             
  *  @return 成功返回section個數(shù),失敗返回 -1
  */
  int iniparser_getnsec(const dictionary * d);
  /*
  *  @brief  獲取某個section值
  *  @param  [IN]  d  dictionary結構的指針
  *  @param  [IN]  n  指定獲取第幾個section值                  
  *  @return 成功返回獲取到的section值,失敗返回NULL
  */
  const char *iniparser_getsecname(const dictionary * d, int n);

3.7 獲取section下key個數(shù)

  /*
  *  @brief  獲取ini配置文件中某個section的key個數(shù)
  *  @param  [IN]  d  dictionary結構的指針 
  *  @param  [IN]  s  section          
  *  @return 返回指定section下的key個數(shù)
  */
  int iniparser_getsecnkeys(dictionary * d, char * s); 
  /*
  *  @brief  獲取ini配置文件中某個section的所有key
  *  @param  [IN]  d  dictionary結構的指針 
  *  @param  [IN]  s  section      
  *  @param  [OUT]  keys  通過這個參數(shù)輸出key,也可以通過返回值獲取     
  *  @return  成功返回指定section下的key,失敗返回NULL
  */
  const char **iniparser_getseckeys(const dictionary *d, const char *s, const char **keys)

3.8 保存dictionary對象到文件中

  /*
  *  @brief  保存dictionary對象到文件中
  *  @param  [IN]  d  dictionary結構的指針   
  *  @param  [IN]  f  已打開的文件描述符
  */
  void iniparser_dump_ini(const dictionary *d, FILE *f);

3.9 釋放dictionary對象

  /*
  *  @brief  釋放dictionary對象
  *  @param  [IN]  d  dictionary結構的指針   
  */
  void iniparser_freedict(dictionary * d);

4 演示

4.1 獲取鍵值

ini文件內(nèi)容

  [head]
  accecpt                        = */*
  length                         = 100
  host                           = 192.168.1.2
  port                           = 8087
  rate                           = 9.98
  [body]
  accept                         = XML
  data                           = json
  length                         = 200

測試代碼

  #include <stdio.h>
  #include <iniparser.h>
  int main(){
  		// 加載配置
  		dictionary* ini = iniparser_load("config.ini");
  		if(ini == NULL){
  			return -1;
  		}
  		// 獲取鍵值
  		const char* cHeadHost = iniparser_getstring(ini, "head:host", "127.0.0.1");
  		printf("cHeadHost %s\n", cHeadHost);
  		const char* cBodyData = iniparser_getstring(ini, "body:data", "welcome");
  		printf("cBodyData %s\n", cBodyData);
  		int iHeadPort = iniparser_getint(ini, "head:port", 80);
  		printf("iHeadPort %d\n", iHeadPort);
  		double iHeadReate = iniparser_getdouble(ini, "head:rate", 9.99);
  		printf("iHeadReate %.2lf\n", iHeadReate);
  		// 釋放dictionary對象
  		iniparser_freedict(ini);
  		return 0;
  }

打印結果

4.2 設置鍵值

ini文件內(nèi)容

  [head]
  accecpt                        = */*
  length                         = 100
  host                           = 192.168.1.2
  port                           = 8087
  rate                           = 9.98
  [body]
  accept                         = XML
  data                           = json
  length                         = 200

測試代碼

  #include <stdio.h>
  #include <iniparser.h>
  int main(){
  	// 加載配置
  	dictionary* ini = iniparser_load("config.ini");
  	if(ini == NULL){
  		return -1;
  	}
  	// 有對應鍵值則修改
  	int ret = iniparser_set(ini, "body:data", "iniparser");
  	if (ret != 0){
  		printf("iniparser_set body:data failed.\n");
  	}
  	// 沒有對應鍵值則添加
  	ret = iniparser_set(ini, "body:msg", "success");
  	if (ret != 0){
  		printf("iniparser_set body:data failed.\n");
  	}
  	// 設置值成功后要進行保存
  	FILE* fp = fopen("config.ini", "w");
  	if( fp == NULL ) {
  		printf("open ini file failed.\n");
  		return -1;
  	}
  	// 保存dictionary對象到file 
  	iniparser_dump_ini(ini, fp);
  	fclose(fp);
  	// 釋放dictionary對象
  	iniparser_freedict(ini);
  	return 0;
  }

設置后新的ini文件內(nèi)容

  [head]
  accecpt                        = */*
  length                         = 100
  host                           = 192.168.1.2
  port                           = 8087
  rate                           = 9.98
  [body]
  accept                         = XML
  data                           = iniparser
  length                         = 200
  msg                            = success

4.3 遍歷section和鍵值

ini文件內(nèi)容

  [head]
  accecpt                        = */*
  length                         = 100
  host                           = 192.168.1.2
  port                           = 8087
  rate                           = 9.98
  [body]
  accept                         = XML
  data                           = iniparser
  length                         = 200
  msg                            = success

測試代碼

  #include <stdio.h>
  #include <iniparser.h>
  int main(){
  	// 加載配置
  	dictionary* ini = iniparser_load("config.ini");
  	if(ini == NULL){
  		return -1;
  	}
  	// 遍歷section
  	int sectionNum = iniparser_getnsec(ini);
  	if(sectionNum != -1){
  		for(int i = 0; i < sectionNum; i++){
  			const char* cSection = iniparser_getsecname(ini, i);	
  			if(cSection != 0){
  				printf("cSection : %s\n", cSection);
  			}
  		}
  	}
  	// 遍歷某個section下的key
  	int keyNum = iniparser_getsecnkeys(ini, "body");
  	//獲取dictionary對象某個section下所有的key 
  	char keys[10][1024] = { 0 };
  	const char **p = (const char **)keys;
  	const char **retKeys = iniparser_getseckeys(ini, "body", p); 
  	for (int i = 0; i < keyNum; i++){
  		printf("%s ", p[i]);
  	}
  	printf("\n");
  	// 釋放dictionary對象
  	iniparser_freedict(ini);
  	return 0;
  }

打印結果

到此這篇關于C語言開源庫iniparser解析ini文件的文章就介紹到這了,更多相關C語言iniparser解析ini文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • QT5編譯使用QFtp的方法步驟

    QT5編譯使用QFtp的方法步驟

    這篇文章主要介紹了QT5編譯使用QFtp的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02
  • C++實現(xiàn)添加圖片水印到PDF文檔

    C++實現(xiàn)添加圖片水印到PDF文檔

    水印是顯示在文檔內(nèi)容后面的淡色文字或圖片,可以用于指示文檔的狀態(tài)(保密、草稿等),本文主要為大家介紹了如何使用?Spire.PDF?for?C++?在?PDF?文檔中添加圖片水印,需要的可以參考下
    2023-11-11
  • 詳解DAG上的DP

    詳解DAG上的DP

    DAG:有向無環(huán)圖。DAG是學習動態(tài)規(guī)劃的基礎,很多問題都可以直接轉化為DAG上的最長路、最短路或路徑計數(shù)問題。本文將詳細介紹DAG上的DP。
    2021-05-05
  • C語言五子棋小游戲實現(xiàn)代碼

    C語言五子棋小游戲實現(xiàn)代碼

    這篇文章主要為大家詳細介紹了C語言五子棋小游戲實現(xiàn)代碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • C語言實現(xiàn)停車場管理系統(tǒng)

    C語言實現(xiàn)停車場管理系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)停車場管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • vs2022?x64?C/C++和匯編混編(案例代碼)

    vs2022?x64?C/C++和匯編混編(案例代碼)

    這篇文章主要介紹了vs2022?x64?C/C++和匯編混編,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-02-02
  • 利用C++實現(xiàn)簡易的.ini配置文件解析器

    利用C++實現(xiàn)簡易的.ini配置文件解析器

    這篇文章主要為大家詳細介紹了如何基于C++編寫一個簡易的.ini配置文件解析器,文中的示例代碼講解詳細,具有一定的借鑒價值,感興趣的小伙伴可以了解一下
    2023-03-03
  • QT實現(xiàn)FTP上傳文件

    QT實現(xiàn)FTP上傳文件

    這篇文章主要為大家詳細介紹了QT實現(xiàn)FTP上傳文件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • C++中的強制類型轉換操作詳解

    C++中的強制類型轉換操作詳解

    C++中提供了四種強制類型轉換技術:static_cast、dynamic_cast、reinterpret_cast和const_cast。這些技術能夠在需要時將一種類型轉換為另一種類型,但需要注意它們的適用條件和安全性。程序員需要根據(jù)具體情況選擇合適的強制類型轉換方式,以確保程序的正確性和可靠性
    2023-04-04
  • C語言 深入淺出講解指針的使用

    C語言 深入淺出講解指針的使用

    指針是C語言中一個非常重要的概念,也是C語言的特色之一。使用指針可以對復雜數(shù)據(jù)進行處理,能對計算機的內(nèi)存分配進行控制,在函數(shù)調(diào)用中使用指針還可以返回多個值
    2022-03-03

最新評論