繁体   English   中英

来自boost-python子模块的python qt float精度

[英]python qt float precision from boost-python submodule

我为我的PyQt程序制作了带有boost-python的cpp子模块,该模块除其他外从zip数据文件中提取一些数据。

在python中测试时,它可以正常工作:

import BPcmods
BPzip = BPcmods.BPzip()
BPzip.open("diagnostics/p25-dev.zip")
l=BPzip.getPfilenames()
t=BPzip.getTempArray([l[1][4],l[1][3]],40.)
print(t[11][:10])

>> [40.1, 40.44, 40.78, 41.11, 41.44, 41.77, 41.77, 42.09, 42.41, 42.73]

如果我在主体部分的开头放了相同的代码,它也提供了相同的数据,但是如果我在调用之后立即放了代码

main.app = QtGui.QApplication(sys.argv)

它突然产生:

[40.0, 40.0, 40.0, 41.0, 41.0, 41.0, 41.0, 42.0, 42.0, 42.0]

为什么?? 发生了什么? 数字仍然是浮点数,但突然将它们四舍五入为最接近的整数?

好吧,这与使用std :: stod将我的数据字符串从数据文件转换为双精度有关。 我不知道为什么,但改为:

boost::algorithm::trim(s);
double val = boost::lexical_cast<double>(s);

使其在pyqt中按预期工作。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM