c/c++写的比较好的读写配置文件的函数或者类

共用版 
.h文件
//----------------------------------------------------------------------------
// 程序名称:   ConfigFile.h
// 程序说明:   类 ConfigFile 的定义
// 程序作者:   
// 程序版本:   1.0
// 开始日期:   1999-01-10
//----------------------------------------------------------------------------

#ifndef __CONFIGFILE_H__
#define __CONFIGFILE_H__

#include <fstream>;
#include <iostream>;

using namespace std;

#define MAX_LINE_LENGTH 300

//----------------------------------------------------------------------------
// 类说明:用于对配置文件进行操作,对于给定的节名和变量名,获得变量的值。
//----------------------------------------------------------------------------
class CConfigFile
{
//构造函数和析构函数
private:    //私有
   
protected:  //保护
   
public:     //公有
    CConfigFile();
    CConfigFile(char *pConfigFileName);
    ~CConfigFile();
   

//属性
private:    //私有
    fstream m_CfgFile;
    short     m_IsOpen;  //文件打开状态
    enum
    {
      IS_COMMENT ,    //是注释
      IS_SESSION ,    //是节名
      IS_VALUE,       //是变量的值
      NOT_FOUND       //没有找到指定的变量名
    };
   
protected:  //保护
   
public:     //公有
   

//服务
private:    //私有
    //查找一个指定的节名
    short  GetSession(char *pStr,char *SessionName);
    //获得变量的值
    short GetContent(char *pStr,char *ValueName,char *RetStr);
   
protected:  //保护
   
public:     //公有
    //打开一个指定的配置文件
    short  Open(char *ConfigFileName);
    //关闭配置文件
    void   Close();
    //根据给定的节名和变量名,从文件中读出变量的值
    short  GetValue(char *Session,char *ValueName,char *RetStr);
    //返回文件打开状态
    short  IsOpen() { return m_IsOpen; };
   
};

#endif //__CONFIGFILE_H__



cpp文件
#include "ConfigFile.h"
#include <string.h>;

//----------------------------------------------------------------------------
// 函数原型: CConfigFile::CConfigFile()
// 函数功能: CConfigFile 构造函数
// 传入参数: 无
// 传出参数: 无
// 函数返回: 无
// 注意事项: 无
//----------------------------------------------------------------------------
CConfigFile::CConfigFile()
{
  m_IsOpen = -1;
}

//----------------------------------------------------------------------------
// 函数原型: CConfigFile::CConfigFile(char *pConfigFileName)
// 函数功能: CConfigFile 构造函数
// 传入参数: char *pConfigFileName  配置文件名
// 传出参数: 无
// 函数返回: 无
// 注意事项: 无
//----------------------------------------------------------------------------
CConfigFile::CConfigFile(char *pConfigFileName)
{
  m_IsOpen = -1;
  Open(pConfigFileName);
}

//----------------------------------------------------------------------------
// 函数原型: CConfigFile::~CConfigFile()
// 函数功能: CConfigFile 析构函数
// 传入参数: 无
// 传出参数: 无
// 函数返回: 无
// 注意事项: 无
//----------------------------------------------------------------------------
CConfigFile::~CConfigFile()
{
  if (m_IsOpen == 0)
    m_CfgFile.close();
}

//----------------------------------------------------------------------------
// 函数原型: short  CConfigFile::Open(char *ConfigFileName)
// 函数功能: 打开指定的配置文件
// 传入参数: char *ConfigFileName  配置文件名
// 传出参数: 无
// 函数返回: 0  打开文件成功
//            -1 打开文件失败
// 注意事项: 无
//----------------------------------------------------------------------------
short  CConfigFile::Open(char *ConfigFileName)
{
  //如果已经有一个文件打开,则先关闭
  if ( m_IsOpen == 0 )
  {
    m_CfgFile.close();
    m_IsOpen == -1;
  }
  //打开指定的配置文件,失败返回-1
  m_CfgFile.open(ConfigFileName,ios::in);
  if( !m_CfgFile )
    return -1;

  m_IsOpen = 0;
  return 0;
}

//----------------------------------------------------------------------------
// 函数原型: void CConfigFile::Close()
// 函数功能: 关闭配置文件
// 传入参数: 无
// 传出参数: 无
// 函数返回: 无
// 注意事项: 无
//----------------------------------------------------------------------------
void CConfigFile::Close()
{
  if ( m_IsOpen == 0 )
    m_CfgFile.close();
}

//----------------------------------------------------------------------------
// 函数原型: short  CConfigFile::GetValue(char *Session,char *ValueName,char *RetStr)
// 函数功能: 从配置文件中读出指定的变量的值
// 传入参数: char *Session   变量所在节的名称
//            char *ValueName 变量的名称
//            char *RetStr    存放返回字符串的空间指针
// 传出参数: 无
// 函数返回: 0  读到指定变量的值
//            -1 未读到指定变量的值
// 注意事项: 无
//----------------------------------------------------------------------------
short  CConfigFile::GetValue(char *Session,char *ValueName,char *RetStr)
{
  char          tmpstr[MAX_LINE_LENGTH];
  short          Flag;
  short   

转载于:https://www.cnblogs.com/java20130726/p/3218451.html

  • 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、付费专栏及课程。

余额充值