Qt创建Json对象时浮点数的精度控制

我们在Qt中使用Json都是使用QJsonDocument、QJsonArray、QJsonObject、QJsonValue等类。
当我们在QJsonObject中插入浮点数字段时,会发现浮点数的小数位数很长,如下所示:

#include <QJsonDocument>
#include <QJsonArray>
#include <QJsonObject>
#include <QJsonParseError>
#include <QJsonValue>

QJsonObject jo;
float v = 0.12132222111222;
ji.Insert("name", v);

//然后转成Json字符串
QJsonDocument doc(jo);
QString str = doc.toJson(QJsonDocument::Compact);

qDebug() << str.toStdString().c_str();
//以上代码会输出:
//{"name":0.12132222111222}

可见,QJsonObject没有对浮点数做任何的精度控制,其小数点后原来多少位,转为Json后还是多少位。

通常我们不需要在json字符串中记录显示这么长的浮点数。
有一种办法是将浮点数作为字符串插入json,代码如下:

QJsonObject jo;
float v = 0.12132222111222;
QString vs = QString::number(v, 'f', 2);
ji.Insert("name", vs);

//然后转成Json字符串
QJsonDocument doc(jo);
QString str = doc.toJson(QJsonDocument::Compact);

qDebug() << str.toStdString().c_str();
//以上代码会输出:
//{"name":"0.12"}

可见浮点数的精度控制在2位了,但是,浮点数被多出来的一对引号(")包裹了,这实际上是把浮点数类型转为字符串类型处理了,这并不是我们想要的。
如果要直接插入精度可控制的浮点数怎么办呢?方法就是,通过QString将浮点数格式化为目的精度的浮点数字符串,然后将浮点数字符串再转回浮点数,最后插入QJsonObject。代码如下:

QJsonObject jo;
float v = 0.12132222111222;
QString vs = QString::number(v, 'f', 2);
double vd = vs.toDouble();
QJsonValue jv(vd);
ji.Insert("name", jv);

//然后转成Json字符串
QJsonDocument doc(jo);
QString str = doc.toJson(QJsonDocument::Compact);

qDebug() << str.toStdString().c_str();
//以上代码会输出:
//{"name": 0.12}

从输出结果可见,烦人的引号(“)消失了,目的达到了。
需要注意的是,以上代码有一个坑要注意:

//这里一定是double类型和toDouble()函数
double vd = vs.toDouble();

//绝对不能是如下float或者toFLoat()函数
float vd = vs.toDouble();
double vd = vs.toFloat();
float vd = vs.toFloat();

不管是出现以上三种中哪一种错误,都会导致精度控制失效。

  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
QJsonObjectQt框架提供的一个类,用于表示JSON对象。它可以用于创建、修改和解析JSON数据。QJsonObject可以插入键值对,并通过键来访问对应的值。 在引用中,代码示例展示了如何使用QJsonObject的一些方法。首先创建了一个空的QJsonObject对象,然后通过insert方法插入了三个键值对。这样就构建了一个包含三个属性的JSON对象。最后,通过QJsonDocument将QJsonObject转化为JSON文档,并可以将其存储为字符串或字节数组。 在引用中,也展示了通过QJsonDocument解析JSON对象的方法。首先将JSON文档转化为QJsonDocument对象,然后可以通过QJsonObject的contains方法判断JSON对象中是否包含指定的键,再通过value方法获取对应的值。根据值的类型,可以使用不同的方法进行获取和转换。 总结来说,QJsonObjectQt提供的用于表示JSON对象的类,可以用于创建、修改和解析JSON数据。可以通过insert方法插入键值对,并通过value方法获取对应的值。同,也可以通过QJsonDocument将JSON对象转化为字符串或字节数组。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [QJsonObject的使用示例](https://blog.csdn.net/ligare/article/details/125393450)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值