'
divisor = sum(list(dept_id2count.values()))
divisor = str(divisor)
getcontext().prec = 4
dept_id2p = {}
for dept_id in dept_id2count:
count = dept_id2count[dept_id]
dividend = str(100 * count) # 被除数
dept_id2p[dept_id] = Decimal(dividend) / Decimal(divisor)
print(Decimal(dividend) / Decimal(divisor))
计算代码如上,输出如下。算每个 count 占总数的比例,最后把比例存到 mysql,保留两位小数。 """
1.781
6.334
0.009013
0.9311
0.02471
0.1105
14.28
24.70
0.4394
11.09
0.01872
4.541
0.06418
13.75
2.486
1.953
0.4429
4.833
4.242
0.08313
1.931
0.7320
0.06604
1.762
3.397
99.99
"""
问题是这些比例加起来不是 100,
一开始用 float 保留两位小数,
后来改成 decimal 四位有效数字,
都没有解决。
求助各位大佬,有没有什么好办法
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.