Uzyskanie wyjątki przy odczycie wartości z pomocą BOOST_FOREACH z litego JSON w C++

0

Pytanie

Otrzymuję następujący błąd podczas odczytu wartości z pomocą BOOST_FOREACH:

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

Czy może ktoś mi pomóc, jak odczytywać wartości z tablicy w poniższym formacie 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

Najlepsza odpowiedź

1

Wczoraj zadał pan bardzo podobny problem. Rozmawialiśmy nie nadużywać biblioteki drzewa do analizy JSON. Ja nawet przewidział:

Dla bardziej poważnego kodu można użyć mapowania typów

Oto jak można rozszerzyć tę odpowiedź, aby przeanalizować cały zestaw w wektor raz:

Żyć Na Колиру

#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";
}

Druk

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

Ja nawet dodał wygodny pasek debugowania na wypadek, gdyby trzeba pomóc dowiedzieć się dokładnie, co dostaniesz w pewnym momencie:

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

W przypadku, jeśli wolisz ręcznie pominięciem JSON bez struktury/wek: coliru.stacked-crooked.com/a/af3ddd1dac30cbd5
sehe

Cześć @sehe, używam read_json z property_tree. Czy możesz mi pomóc, jak wykonać ręczny bypass JSON za pomocą read_json i property_tree ( jak w moim przykładzie).
sas

Oczywiście. coliru.stacked-crooked.com/a/d444f8aaf6c611f5 (w zasadzie to samo, co w moim starym odpowiedzi). Jednak nie rób tego. I przeczytaj o ograniczeniach zaplecza części "JSON" w drzewie właściwości Boost: boost.org/doc/libs/1_77_0/doc/html/property_tree/...
sehe

W innych językach

Ta strona jest w innych językach

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