C++读配置文件类

C++读配置文件类

config.h

#ifndef RR_CONFIG_H_

#define RR_CONFIG_H_

#include <string>

#include <map>

class RrConfig

{

public:

    RrConfig()

    {

    }

    ~RrConfig()

    {

    }

    bool ReadConfig(const std::string & filename);//配置文件接口

    std::string ReadString(const char* section, const char* item, const char* default_value);//string类型

    int ReadInt(const char* section, const char* item, const int& default_value);//以int类型

    float ReadFloat(const char* section, const char* item, const float& default_value);//以浮点类型

private:

    bool IsSpace(char c);

    bool IsCommentChar(char c);

    void Trim(std::string & str);

    bool AnalyseLine(const std::string & line, std::string& section, std::string & key, std::string & value);



private:

    std::map<std::string, std::map<std::string, std::string> >settings_;

};

//}

#endif


config.cpp

#include "configfile.h"
#include <fstream>
#include <stdlib.h>

bool RrConfig::IsSpace(char c)
{
    if (' ' == c || '\t' == c)
        return true;
    return false;
}

bool RrConfig::IsCommentChar(char c)
{
    switch (c) {
    case '#':
        return true;
    default:
        return false;
    }
}

void RrConfig::Trim(std::string & str)
{
    if (str.empty())
    {
        return;
    }
    int i, start_pos, end_pos;
    for (i = 0; i < str.size(); ++i) {
        if (!IsSpace(str[i])) {
            break;
        }
    }
    if (i == str.size())
    {
        str = "";
        return;
    }
    start_pos = i;
    for (i = str.size() - 1; i >= 0; --i) {
        if (!IsSpace(str[i])) {
            break;
        }
    }
    end_pos = i;
    str = str.substr(start_pos, end_pos - start_pos + 1);
}

bool RrConfig::AnalyseLine(const std::string & line, std::string& section, std::string & key, std::string & value)
{
    if (line.empty())
        return false;
    int start_pos = 0, end_pos = line.size() - 1, pos, s_startpos, s_endpos;
    if ((pos = line.find("#")) != -1)
    {
        if (0 == pos)
        {
            return false;
        }
        end_pos = pos - 1;
    }
    if (((s_startpos = line.find("[")) != -1) && ((s_endpos = line.find("]"))) != -1)
    {
        section = line.substr(s_startpos+1, s_endpos -1);
        return true;
    }
    std::string new_line = line.substr(start_pos, start_pos + 1 - end_pos);
    if ((pos = new_line.find('=')) == -1)
        return false;
    key = new_line.substr(0, pos);
    value = new_line.substr(pos + 1, end_pos + 1 - (pos + 1));
    Trim(key);
    if (key.empty()) {
        return false;
    }
    Trim(value);
    if ((pos = value.find("\r")) > 0)
    {
        value.replace(pos, 1, "");
    }
    if ((pos = value.find("\n")) > 0)
    {
        value.replace(pos, 1, "");
    }
    return true;
}

bool RrConfig::ReadConfig(const std::string & filename)
{
    settings_.clear();
    std::ifstream infile(filename.c_str(),std::ios::in | std::ios::binary);
    if (!infile) {
        printf("The profile does not exist!");
        return false;
    }
    std::string line, key, value, section;
    std::map<std::string, std::string> k_v;
    std::map<std::string, std::map<std::string, std::string> >::iterator it;
    while (getline(infile, line))
    {
        if (AnalyseLine(line, section, key, value))
        {
            it = settings_.find(section);
            if (it != settings_.end())
            {
                k_v[key] = value;
                it->second = k_v;
            }
            else
            {
                k_v.clear();
                settings_.insert(std::make_pair(section, k_v));
            }
        }
        key.clear();
        value.clear();
    }
    infile.close();
    return true;
}

std::string RrConfig::ReadString(const char* section, const char* item, const char* default_value)
{
    std::string tmp_s(section);
    std::string tmp_i(item);
    std::string def(default_value);
    std::map<std::string, std::string> k_v;
    std::map<std::string, std::string>::iterator it_item;
    std::map<std::string, std::map<std::string, std::string> >::iterator it;
    it = settings_.find(tmp_s);
    if (it == settings_.end())
    {
        return def;
    }
    k_v = it->second;
    it_item = k_v.find(tmp_i);
    if (it_item == k_v.end())
    {
        return def;
    }
    return it_item->second;
}

int RrConfig::ReadInt(const char* section, const char* item, const int& default_value)
{
    std::string tmp_s(section);
    std::string tmp_i(item);
    std::map<std::string, std::string> k_v;
    std::map<std::string, std::string>::iterator it_item;
    std::map<std::string, std::map<std::string, std::string> >::iterator it;
    it = settings_.find(tmp_s);
    if (it == settings_.end())
    {
        return default_value;
    }
    k_v = it->second;
    it_item = k_v.find(tmp_i);
    if (it_item == k_v.end())
    {
        return default_value;
    }
    return atoi(it_item->second.c_str());
}

float RrConfig::ReadFloat(const char* section, const char* item, const float& default_value)
{
    std::string tmp_s(section);
    std::string tmp_i(item);
    std::map<std::string, std::string> k_v;
    std::map<std::string, std::string>::iterator it_item;
    std::map<std::string, std::map<std::string, std::string> >::iterator it;
    it = settings_.find(tmp_s);
    if (it == settings_.end())
    {
        return default_value;
    }
    k_v = it->second;
    it_item = k_v.find(tmp_i);
    if (it_item == k_v.end())
    {
        return default_value;
    }
    return atof(it_item->second.c_str());
}


config.ini 配置文件类型

[PUBDDSSTRING]
data_type=string  #通过“#”注释
domain_id=0
idl_data=hello world!
period=1000
sample_count=1000
topic_name=Topic

[SUBDDSSTRING]
data_type=string
domain_id=0
idl_data=hello world!
period=1000
sample_count=1000
topic_name=Topic

使用

RrConfig config;//实例化
config.ReadConfig("config.ini");//加载配置文件
int id_value = config.ReadInt("PUBDDSSTRING", "domain_id", 0);//获取PUBDDSSTRING下的domaib_id的值,0为默认值,若无该配置项返回0
std::string name_value = config.ReadString("SUBDDSSTRING", "topic_name", "");//获取SUBDDSSTRING下的topic_name的值

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值