在我做实验时,测量到了多组数据,需要对这些数据进行统一运算,于是我写了一个python代码去算,结果发现计算结果出现了很大的问题。如下:
a = []
# 在下面修改b的值
# *******************************************************************************
b = '''21.37
21.38
21.39
21.4
21.41
21.415
21.425
21.43
21.44
21.45
21.46
21.465
21.47
21.48
21.5
21.52
21.58'''
# *******************************************************************************
b = b.split(sep='\n') # 获得列表
alist = list(map(float, b)) # 获得浮点数列表
for i in alist:
c = i - 21.37
# a.append('%.3f' % c)
a.append(c)
print(a)
直接利用原始数据去计算时,发现结果时这样的:
一看结果就是错误的, 于是我去查找了float的相关运算,找到了问题,问题比较冗杂就不多叙述了,总之是二进制计算时计算机的问题,我们只需要限制小数位就能解决。
于是我顺便就总结了以下占位字符顺便限制小数位的方法。
减少序列以方便观察:
a = []
# 在下面修改b的值
# *******************************************************************************
b = '''15445
46654
1000
100
1'''
# *******************************************************************************
# 一次性输入这一列数只能被当做字符串处理,但map函数可以修改n字符串中每个元素的类型
b = b.split(sep='\n') # 获得列表
alist = list(map(float, b)) # 获得浮点数列表
for i in alist:
c = i - 21.37
a.append('%.3f' % c)
for j in a:
print(j)
①%d %f %s
append行改为
a.append('%.3f' % c)
利用%f代表浮点数,其他还有%d整数,%s字符串。
%.3f就代表小数点后面保留3位小数。以小数点作为分割,前面代表输出位数(包括小数点),后面代表小数部分。
%3.f代表包括小数点在内总共保留3位且小数部分保留0位,那么就意味着整数部分保留3位。但如果计算结果超过3位也会强制性保留至计算结果,如果计算结果小于3位,那么会从个位依次往高位补充空格。例如:
a.append('%.f' % c)
a.append('%6.f' % c)
a.append('%8.2f' % c)
这样做可以方便分别观察小数部分和整数部分。
②format格式化占位字符
a.append('{:.3f}'.format(c))
format函数的使用还有很多很多,具体可以自行学习。