使用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();


有点冗长,是的,其他人想出了一个更好的解决方案,然后可以发布它。

09-10 00:26