Получение исключения при чтении значений с помощью BOOST_FOREACH из массива JSON в C++

0

Вопрос

Я получаю следующую ошибку при чтении значений с помощью BOOST_FOREACH:

Unhandled exception at 0x76FCB502 in JSONSampleApp.exe: Microsoft C++ exception: boost::wrapexcept<boost::property_tree::ptree_bad_path> at memory location 0x00CFEB18.

Может ли кто-нибудь помочь мне, как считывать значения из массива в приведенном ниже формате JSON?

#include <string>
#include <iostream>
#include <boost/property_tree/json_parser.hpp>
#include <boost/foreach.hpp>

using namespace std;

using boost::property_tree::ptree;

int main()
{
const char* f_strSetting = R"({"Class": [{"Student": {"Name":"John","Course":"C++"}}]})";

    boost::property_tree::ptree pt1;
    std::istringstream l_issJson(f_strSetting);
    boost::property_tree::read_json(l_issJson, pt1);

    BOOST_FOREACH(boost::property_tree::ptree::value_type & v, pt1.get_child("Class.Student"))
    {
        std::string l_strName;
        std::string l_strCourse;
        l_strName = v.second.get <std::string>("Name");
        l_strCourse = v.second.get <std::string>("Course");

        cout << l_strName << "\n";
        cout << l_strCourse << "\n";
    }

    return 0;
}
boost boost-propertytree c++ json
2021-11-23 13:32:29
1

Лучший ответ

1

Вчера вы задали очень похожий вопрос. Мы говорили вам не злоупотреблять библиотекой дерева свойств для анализа JSON. Я даже предвидел:

Для более серьезного кода вы можете использовать сопоставление типов

Вот как вы бы расширили этот ответ, чтобы проанализировать весь массив в вектор сразу:

Жить На Колиру

#include <boost/json.hpp>
#include <boost/json/src.hpp> // for header-only
#include <iostream>
#include <string>
namespace json = boost::json;

struct Student {
    std::string name, course;

    friend Student tag_invoke(json::value_to_tag<Student>, json::value const& v) {
        std::cerr << "DEBUG: " << v << "\n";
        auto const& s = v.at("Student");
        return {
            value_to<std::string>(s.at("Name")),
            value_to<std::string>(s.at("Course")),
        };
    }
};

using Class = std::vector<Student>;

int main()
{
    auto doc = json::parse(R"({ "Class": [
            { "Student": { "Name": "John", "Course": "C++" } },
            { "Student": { "Name": "Carla", "Course": "Cobol" } }
        ]
    })");
    auto c = value_to<Class>(doc.at("Class"));

    for (Student const& s : c)
        std::cout << "Name: " << s.name << ", Course: " << s.course << "\n";
}

Печатание

Name: John, Course: C++
Name: Carla, Course: Cobol

Я даже добавил удобную строку отладки на случай, если вам понадобится помочь точно выяснить, что вы получите в какой-то момент:

DEBUG: {"Student":{"Name":"John","Course":"C++"}}
DEBUG: {"Student":{"Name":"Carla","Course":"Cobol"}}
2021-11-23 15:05:58

В случае, если вы предпочитаете ручной обход JSON без структуры/вектора: coliru.stacked-crooked.com/a/af3ddd1dac30cbd5
sehe

Привет @sehe, я использую read_json с property_tree. Можете ли вы помочь мне, как выполнить ручной обход JSON с помощью read_json и property_tree ( как в моем примере).
sas

Конечно. coliru.stacked-crooked.com/a/d444f8aaf6c611f5 (в основном то же самое, что и в моем старом ответе). Однако не делай этого. И прочитайте об ограничениях серверной части "JSON" в дереве свойств Boost: boost.org/doc/libs/1_77_0/doc/html/property_tree/...
sehe

На других языках

Эта страница на других языках

Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................