使用QJson解析此数据:
"ShelveId": {
"0": {
"BeBoardId": {
"0": {
"connectionId": "board0", .... followed by more data
我想比这样做更快地遍历这张桌子。所有地图均为QVariantMaps:
map_BeBoardId = map_ShelveId["0"].toMap();
map_BeBoardId = map_BeBoardId["BeBoardId"].toMap();
auto temp = map_BeBoardId["0"].toMap();
m_connectionId = temp["connectionId"].toString();
qDebug() << m_connectionId;
哪个有效,并正确返回我的connectionId“ board0”。
我想做的是这样的:
map_BeBoardId = map_ShelveId["0"].toMap();
map_BeBoardId = map_BeBoardId["BeBoardId", "0"].toMap();
m_connectionId = map_BeBoardId["connectionId"].toString();
qDebug() << m_connectionId;
这给我返回了一个空的connectionId。
不,我不能在这里使用列表,因为有时根据连接的内容,我们可能会有一个“ 1”和“ 4”的搁置ID。
最佳答案
对于疲倦的旅行者,经过各种尝试,这是我想出的:
auto temp = map_BeBoardId.value("0").toMap().value("connectionId").toString();
有点冗长,是的,其他人想出了一个更好的解决方案,然后可以发布它。