Невозможно прочитать graphML, используя boost :: read_graphml

Я использую версию Boost 1.64 и пытаюсь прочитать файл GraphML, используя boost :: read_graphml ..
Код компилируется, но выдает исключение при запуске:

прерывание вызывается после создания экземпляра ‘boost :: exception_detail :: clone_impl>’
what (): ошибка разбора: нераспознанный тип «» для ключа
Прервать (ядро сброшено)

test.cpp

#include <boost/graph/graph_utility.hpp>
#include <boost/property_map/property_map.hpp>
#include <boost/property_map/dynamic_property_map.hpp>
#include <boost/graph/adjacency_list.hpp>
#include <boost/graph/graphml.hpp>
#include <fstream>

struct GraphData {
std::string Name;
};
struct VertexProperty
{
std::string Name ;
};

struct EdgeProperty
{
std::string Name ;
};

using Graph = boost::adjacency_list<boost::setS, boost::vecS, boost::directedS, GraphData>;

Graph ReadGraph(std::string const& fileName) {
Graph graph;
boost::dynamic_properties dp;
dp.property("Name", boost::get(&GraphData::Name, graph));

std::ifstream file(fileName);
boost::read_graphml(file, graph, dp);

return graph;
}

int main() {
Graph g = ReadGraph("111.graphml");
print_graph(g, get(&GraphData::Name, g));

}

111.graphml

<?xml version="1.0" encoding="UTF-8"?>
<graphml xmlns="http://graphml.graphdrawing.org/xmlns" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://graphml.graphdrawing.org/xmlns http://graphml.graphdrawing.org/xmlns/1.0/graphml.xsd">
<key id="key0" for="node" attr.name="Name" attr.type="string" />
<graph id="G" edgedefault="directed" parse.nodeids="canonical" parse.edgeids="canonical" parse.order="nodesfirst">
<node id="n0">
<data key="key0">A</data>
</node>
<node id="n1">
<data key="key0">D</data>
</node>
<node id="n2">
<data key="key0">B</data>
</node>
<node id="n3">
<data key="key0">C</data>
</node>
<edge id="e0" source="n0" target="n1">
</edge>
<edge id="e1" source="n2" target="n3">
</edge>
</graph>
</graphml>

Ценю любую помощь по этому вопросу !!!

1

Решение

Я не могу воспроизвести это, используя показанный код / ​​xml:

Однако я отмечаю, что вы используете GraphData в положении, соответствующем пачке свойств Vertex.

Возможно, вы хотели

using Graph = boost::adjacency_list<boost::setS, boost::vecS,
boost::directedS, VertexProperty, EdgeProperty, GraphData>;

А потом использовать boost::get(&VertexProperty::Name, graph) вместо GraphData имущество.

Еще более предположительно, вы можете поручить анализатору graphml игнорировать любые внешние свойства, которые не отображаются:

boost::dynamic_properties dp(boost::ignore_other_properties);

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

#include <boost/graph/adjacency_list.hpp>
#include <boost/graph/graph_utility.hpp>
#include <boost/graph/graphml.hpp>
#include <boost/property_map/dynamic_property_map.hpp>
#include <boost/property_map/property_map.hpp>
#include <fstream>

struct GraphData { std::string Name; };
struct VertexProperty { std::string Name; };
struct EdgeProperty { std::string Name; };

using Graph = boost::adjacency_list<boost::setS, boost::vecS, boost::directedS, VertexProperty, EdgeProperty, GraphData>;

Graph ReadGraph(std::istream& is) {
Graph graph;
boost::dynamic_properties dp(boost::ignore_other_properties);
dp.property("Name", boost::get(&VertexProperty::Name, graph));

boost::read_graphml(is, graph, dp);

return graph;
}

extern std::string const graphml_111;

int main() {
std::istringstream is(graphml_111);
Graph g = ReadGraph(is);
print_graph(g, get(&VertexProperty::Name, g));
}

std::string const graphml_111 = R"(<?xml version="1.0" encoding="UTF-8"?>
<graphml xmlns="http://graphml.graphdrawing.org/xmlns" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://graphml.graphdrawing.org/xmlns http://graphml.graphdrawing.org/xmlns/1.0/graphml.xsd">
<key id="key0" for="node" attr.name="Name" attr.type="string" />
<graph id="G" edgedefault="directed" parse.nodeids="canonical" parse.edgeids="canonical" parse.order="nodesfirst">
<node id="n0">
<data key="key0">A</data>
</node>
<node id="n1">
<data key="key0">D</data>
</node>
<node id="n2">
<data key="key0">B</data>
</node>
<node id="n3">
<data key="key0">C</data>
</node>
<edge id="e0" source="n0" target="n1">
</edge>
<edge id="e1" source="n2" target="n3">
</edge>
</graph>
</graphml>)";

Печать

A --> D
D -->
B --> C
C -->
1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]