1

ブーストプログラムオプションを使用してiniファイルから読み取るのに問題があります。問題は、ハッシュマークを含むキーです(簡単な例)。

[セクション]
key= "xxx#yyy"

キーを取得すると、「xxx」が返されます。これは、ハッシュマークがコメントの先頭として解釈されているように見えるため、行の残りの部分がスキップされるためです。残念ながら、値は正規表現であるため、「#」を他の文字に置き換えることはできません。ハッシュマークを引用する方法が見つかりませんでした。正規表現が変更されてさらに読みにくくなるため、引用しない方がよいでしょう。

iniファイルパーサーを書き直さずにこの問題に対処する方法はありますか?助けてくれてありがとう。

キーを取得するための私のコードは次のようになります。

std::string key;
boost::program_options::options_description opDesc("test");
opDesc.add_options()("section.key", po::value<string>(&key))
std::ifstream ifs("file.ini");
boost::program_options::parse_config_file(ifs, opDesc);
4

1 に答える 1

1

おそらく、ここで「プログラムオプションを解析しています」のポイントをはるかに超えているので、BoostPropertyTreeの使用を開始するときです。

http://www.boost.org/doc/libs/1_46_1/doc/html/property_tree.html

プロパティツリーには、JSON、Xml、Ini(<-- you are here)、およびINFO形式のパーサー/フォーマッターがあります。リンクされたページは、正確にどのラウンドトリップを指定するかを数行で指定します(JSON固有のタイプ情報と、場合によっては末尾の空白を除いて、ほとんどのものがラウンドトリップします)。

INI形式(使用しているものに近いため)とINFO設定(階層的にネストされたセクションに加えて、より多くの文字列構文があるため)が必要だと思います。


サンプルから:

#include <boost/property_tree/ptree.hpp>
#include <boost/property_tree/xml_parser.hpp>
#include <boost/foreach.hpp>
#include <string>
#include <set>
#include <exception>
#include <iostream>

struct debug_settings
{
    std::string m_file;               // log filename
    int m_level;                      // debug level
    std::set<std::string> m_modules;  // modules where logging is enabled
    void load(const std::string &filename);
    void save(const std::string &filename);
};

void debug_settings::load(const std::string &filename)
{
    using boost::property_tree::ptree;
    ptree pt;
    read_xml(filename, pt);
    m_file = pt.get<std::string>("debug.filename");
    m_level = pt.get("debug.level", 0);
    BOOST_FOREACH(ptree::value_type &v, pt.get_child("debug.modules"))
        m_modules.insert(v.second.data());
}

void debug_settings::save(const std::string &filename)
{
    using boost::property_tree::ptree;
    ptree pt;
    pt.put("debug.filename", m_file);
    pt.put("debug.level", m_level);
    BOOST_FOREACH(const std::string &name, m_modules)
        pt.add("debug.modules.module", name);
    write_xml(filename, pt);
}

int main()
{
    try
    {
        debug_settings ds;
        ds.load("debug_settings.xml");
        ds.save("debug_settings_out.xml");
        std::cout << "Success\n";
    }
    catch (std::exception &e)
    {
        std::cout << "Error: " << e.what() << "\n";
    }
    return 0;
}
于 2011-07-05T07:23:16.053 に答える