linux c语言 ini文件,C 读取ini文件的实例详解

C 读取ini文件

前言:

在Windows下可以用GetPrivateProfileString或GetPrivateProfileInt方便读取.ini配置文件内容,但是在Linux平台上就一筹莫展了。为了解决该问题,打算用C来读取.ini,即可不受平台的限制了。

#define CONF_FILE_PATH "Config.ini"

#include

#ifdef WIN32

#include

#include

#else

#define MAX_PATH 260

#include

#include

#include

#include

#include

#endif

char g_szConfigPath[MAX_PATH];

//获取当前程序目录

int GetCurrentPath(char buf[],char *pFileName)

{

#ifdef WIN32

GetModuleFileName(NULL,buf,MAX_PATH);

#else

char pidfile[64];

int bytes;

int fd;

sprintf(pidfile, "/proc/%d/cmdline", getpid());

fd = open(pidfile, O_RDONLY, 0);

bytes = read(fd, buf, 256);

close(fd);

buf[MAX_PATH] = '\0';

#endif

char * p = &buf[strlen(buf)];

do

{

*p = '\0';

p--;

#ifdef WIN32

} while('\\' != *p );

#else

} while('/' != *p );

#endif

p++;

//配置文件目录

memcpy(p,pFileName,strlen(pFileName));

return 0;

}

//从INI文件读取字符串类型数据

char *GetIniKeyString(char *title,char *key,char *filename)

{

FILE *fp;

char szLine[1024];

static char tmpstr[1024];

int rtnval;

int i = 0;

int flag = 0;

char *tmp;

if((fp = fopen(filename,"r")) == NULL)

{

printf("have no such file \n");

return "";

}

while(!feof(fp))

{

rtnval = fgetc(fp);

if(rtnval == EOF)

{

break;

}

else

{

szLine[i++] = rtnval;

}

if(rtnval == '\n')

{

#ifndef WIN32

i--;

#endif

szLine[--i] = '\0';

i = 0;

tmp = strchr(szLine, '=');

if(( tmp != NULL )&&(flag == 1))

{

if(strstr(szLine,key)!=NULL)

{

//注释行

if ('#' == szLine[0])

{

}

else if ( '\/' == szLine[0] && '\/' == szLine[1] )

{

}

else

{

//找打key对应变量

strcpy(tmpstr,tmp+1);

fclose(fp);

return tmpstr;

}

}

}

else

{

strcpy(tmpstr,"[");

strcat(tmpstr,title);

strcat(tmpstr,"]");

if( strncmp(tmpstr,szLine,strlen(tmpstr)) == 0 )

{

//找到title

flag = 1;

}

}

}

}

fclose(fp);

return "";

}

//从INI文件读取整类型数据

int GetIniKeyInt(char *title,char *key,char *filename)

{

return atoi(GetIniKeyString(title,key,filename));

}

int main(int argc,char* argv[])

{

char buf[MAX_PATH];

memset(buf,0,sizeof(buf));

GetCurrentPath(buf,CONF_FILE_PATH);

strcpy(g_szConfigPath,buf);

int iCatAge;

char szCatName[32];

iCatAge = GetIniKeyInt("CAT","age",g_szConfigPath);

strcpy(szCatName,GetIniKeyString("CAT","name",g_szConfigPath));

return 0;

}

#define CONF_FILE_PATH "Config.ini"

#include

#ifdef WIN32

#include

#include

#else

#define MAX_PATH 260

#include

#include

#include

#include

#include

#endif

char g_szConfigPath[MAX_PATH];

//获取当前程序目录

int GetCurrentPath(char buf[],char *pFileName)

{

#ifdef WIN32

GetModuleFileName(NULL,buf,MAX_PATH);

#else

char pidfile[64];

int bytes;

int fd;

sprintf(pidfile, "/proc/%d/cmdline", getpid());

fd = open(pidfile, O_RDONLY, 0);

bytes = read(fd, buf, 256);

close(fd);

buf[MAX_PATH] = '\0';

#endif

char * p = &buf[strlen(buf)];

do

{

*p = '\0';

p--;

#ifdef WIN32

} while( '\\' != *p );

#else

} while( '/' != *p );

#endif

p++;

//配置文件目录

memcpy(p,pFileName,strlen(pFileName));

return 0;

}

//从INI文件读取字符串类型数据

char *GetIniKeyString(char *title,char *key,char *filename)

{

FILE *fp;

char szLine[1024];

static char tmpstr[1024];

int rtnval;

int i = 0;

int flag = 0;

char *tmp;

if((fp = fopen(filename, "r")) == NULL)

{

printf("have no such file \n");

return "";

}

while(!feof(fp))

{

rtnval = fgetc(fp);

if(rtnval == EOF)

{

break;

}

else

{

szLine[i++] = rtnval;

}

if(rtnval == '\n')

{

#ifndef WIN32

i--;

#endif

szLine[--i] = '\0';

i = 0;

tmp = strchr(szLine, '=');

if(( tmp != NULL )&&(flag == 1))

{

if(strstr(szLine,key)!=NULL)

{

//注释行

if ('#' == szLine[0])

{

}

else if ( '\/' == szLine[0] && '\/' == szLine[1] )

{

}

else

{

//找打key对应变量

strcpy(tmpstr,tmp+1);

fclose(fp);

return tmpstr;

}

}

}

else

{

strcpy(tmpstr,"[");

strcat(tmpstr,title);

strcat(tmpstr,"]");

if( strncmp(tmpstr,szLine,strlen(tmpstr)) == 0 )

{

//找到title

flag = 1;

}

}

}

}

fclose(fp);

return "";

}

//从INI文件读取整类型数据

int GetIniKeyInt(char *title,char *key,char *filename)

{

return atoi(GetIniKeyString(title,key,filename));

}

int main(int argc, char* argv[])

{

char buf[MAX_PATH];

memset(buf,0,sizeof(buf));

GetCurrentPath(buf,CONF_FILE_PATH);

strcpy(g_szConfigPath,buf);

int iCatAge;

char szCatName[32];

iCatAge = GetIniKeyInt("CAT","age",g_szConfigPath);

strcpy(szCatName,GetIniKeyString("CAT","name",g_szConfigPath));

return 0;

}

下边是配置文件:

[CAT]

age=2

name=Tom

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
纯c读写ini配置文件 用c/c++读写ini配置文件有不少第三方的开源库,如iniparser、libini、rwini、UltraLightINIParser等,但都不理想,往往代码较大、功能较弱、 接口使用不方便。尤其在大小写处理、前后空格、各种注释、跨平台换行符支持、带引号字符串处理、无section操作、原格式保持等方面存在问题。 现将本人精心制作的ini读写程序源码奉献给大家,纯c编写,简洁好用。支持windows和linux。 主要特点: 1、支持;和#注释符号,支持行尾注释。 2、支持带引号'或"成对匹配的字符串,提取时自动去引号。引号中可带其它引号或;#注释符。 3、支持无section或空section(名称为空)。 4、支持10、16、8进制数,0x开头为16进制数,0开头为8进制。 5、支持section、key或=号前后带空格。 6、支持\n、\r、\r\n或\n\r换行格式。 7、不区分section、key大小写,但写入时以新串为准,并保持其大小写。 8、新增数据时,若section存在则在该节最后一个有效数据后添加,否则在文件尾部添加。 9、支持指定key所在整行删除,即删除该键值,包括注释。 10、可自动跳过格式错误行,修改时仍然保留。 11、修改时保留原注释:包括整行注释、行尾注释(包括前面空格)。 12、修改时保留原空行。以上三点主要是尽量保留原格式。 不足之处: 1、不支持单key多value(逗号分割),只能一次性提取后自行处理。 2、不支持同名重复section和key。(重复section可视为错误,重复key则可能造成分歧) 3、不能提取所有section或key名称。 使用只需两个文件inirw.h、inirw.c,另有测试程序和工程文件,支持windows和linux

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值