我有这组数据:
[ step:-1, name:"BaseName1", value:v1 ]
[ step:-1, name:"BaseName2", value:v2 ]
[ step:2, name:"ParamName3", value:v3 ]
[ step:2, name:"ParamName4", value:v4 ]
[ step:0, name:"ParamName5", value:v5 ]
[ step:0, name:"ParamName6", value:v6 ]
[ step:1, name:"ParamName7", value:v7 ]
[ step:1, name:"ParamName8", value:v8 ]
我想转换为 QVariant,如下所示:
[
"BaseName1": v1,
"BaseName2": v2,
"steps": [{
"ParamName5": v5,
"ParamName6": v6
}, {
"ParamName7": v7,
"ParamName8": v8
}, {
"ParamName3": v3,
"ParamName4": v4
}
]
]
我想应该是这样的:
QVariantMap params;
params["Base_param_1"] = value;
params["Base_param_2"] = value2;
params["steps"] = QVariantList();
但是对于数组,我需要对数据进行排序;params["steps"]
这意味着我应该在第 1 步和第 3 步之前插入第 0步(第 2 步应该为空)。
此外,对输入数据进行排序不是一种选择。
我尝试使用以下代码来实现这一点:
struct Params{
QString name;
QVariant value;
int step;/* -1 for base param */
};
QList<Params> _params = (...);
QVariantMap v_settings;
QVariantList v_steps;
for(int i=0; i<_params.size(); i++){
const Param ¶m = _params[i];
if( param.index == -1 ){
v_settings.insert(param.name, param.value);
}
else {
// if list too small, append empties to the list until it exists
while( v_steps.size() < param.index ){
QVariantMap map;
v_steps.append(map);
}
v_steps.at(param.index).toMap().insert(param.name, param.value);
}
}
v_settings.insert("steps", v_steps);
但是当遇到这一行时,代码在某些时候失败,索引超出范围:
v_steps.at(param.index).toMap().insert(param.name, param.value);
所以我猜我的“用空地图填充”循环以某种方式失败了。我该怎么办?