f = lambda x, n: round(x, n - len(str(int(x))));
定义了一个方法f,用来实现你所说的功能。
输入:
f(123.456789, 8)
输出:
123.45678
输入:
f(1.23456789, 8)
输出:
1.2345679000000001
f接收2个参数,第一个参数是要求有效位数的数字,第二个参数是设置有效位数。第二次输出中的数字不够准确,这跟python处理小数的方式有关,如果想要准确的数字可以使用python decimal类。或者用python3k
扩展资料
#include <stdio.h>
#define C "C Programming"int main(void)
{
int a=12345;float b=5.12345678;
char e,d,f;
scanf("%c %c %c",&e,&d,&f);
printf("int is:%d\n",a);
printf("float is:%f\n",b);
printf("char is:%s\n",C);return 0;
}
1,对于浮点数
a=1.36852
a=round(a,2)
print a
#结果1.36
2,对于整数
from decimal import Decimal
a=1
a=Decimal(a).quantize(Decimal('0.00'))
print a
#结果1.00
3,通用方法
a=1
a=("%.2f" % a)
print a
#结果1.00
参考资料:百度百科 Python
如
a=3.251551
round(a,2)可以把a保留二位小数
round函数是Python内置的一个函数,可以用来对数值进行四舍五入。其语法格式如下:
```
round(number, ndigits)
```
其中number表示需要进入四舍五入的数值,ndigits表示需要保留的小数位数。当ndigits为正数时,四舍五入到小数点后ndigits位;当ndigits为负数时,四舍五入到整数位。
例如:
```
a = 3.1415926
b = round(a, 2)
print(b)
```
输出结果为:
```
3.14
```
这里将a保留两位小数,得到的结果为3.14。
需要注意的是,使用round函数保留小数时可能会出现精度丢失的问题。例如:
```
a = 1.005
b = round(a, 2)
print(b)
```
输出结果为:
```
1.0
```
这里本来想将1.005保留两位小数得到1.01,但由于浮点数的精度问题,最终得到的结果为1.0。因此,在使用round函数保留小数时,需要注意精度问题。
2、使用字符串格式化
Python中的字符串格式化可以用来输出内容进行格式化,包括保留小数。其中,使用格式化字符串的方式可以通过%进行实现,也可以使用format函数进行实现。
①使用%进行格式化
使用%进行格式化时,需要在格式化字符串中使用%.nf的形式指定需要保留的小数位数。其中,n表示需要保留的小数位数。
例如:
```
a = 3.1415926
b = "%.2f" % a
print(b)
```
输出结果为:
```
3.14
```
这里将a保留两位小数,得到的结果为3.14。
②使用format函数进行格式化
使用format函数进行格式化时,需要在格式化字符串中使用{:.nf}的形式指定需要保留的小数位数。其中,n表示需要保留的小数位数。
例如:
```
a = 3.1415926
b = "{:.2f}".format(a)
print(b)
```
输出结果为:
```
3.14
```
这里将a保留两位小数,得到的结果为3.14。