python 格式化输出
文章出处:https://www.cnblogs.com/fat39/p/7159881.html
一、格式化输出
1、整数的输出
%o —— oct 八进制
%d —— dec 十进制
%x —— hex 十六进制
1 >>> print("%o" % 20) 2 24 3 >>> print("%d" % 20) 4 20 5 >>> print("%x" % 20) 6 14
2、浮点数输出
(1)格式化输出
%f ——保留小数点后面六位有效数字
%.3f,保留3位小数位
%e ——保留小数点后面六位有效数字,指数形式输出
%.3e,保留3位小数位,使用科学计数法
%g ——在保证六位有效数字的前提下,使用小数方式,否则使用科学计数法
%.3g,保留3位有效数字,使用小数或科学计数法

1 >>> print("%f" % 1.11) # 默认保留6位小数 2 1.110000 3 >>> print("%.1f" % 1.11) # 取1位小数 4 1.1 5 >>> print("%e" % 1.11) # 默认6位小数,用科学计数法 6 1.110000e+00 7 >>> print("%.3e" % 1.11) # 取3位小数,用科学计数法 8 1.110e+00 9 >>> print("%g" % 1111.1111) # 默认6位有效数字 10 1111.11 11 >>> print("%.7g" % 1111.1111) # 取7位有效数字 12 1111.111 13 >>> print("%.2g" % 1111.1111) # 取2位有效数字,自动转换为科学计数法 14 1.1e+03

(2)内置round()
round(number[, ndigits])
参数:
number - 这是一个数字表达式。
ndigits - 表示从小数点到最后四舍五入的位数。默认值为0。
返回值
该方法返回x的小数点舍入为n位数后的值。
round()函数只有一个参数,不指定位数的时候,返回一个整数,而且是最靠近的整数,类似于四舍五入,当指定取舍的小数点位数的时候,一般情况也是使用四舍五入的规则,但是碰到.5的情况时,如果要取舍的位数前的小数是奇数,则直接舍弃,如果是偶数则向上取舍。
注:“.5”这个是一个“坑”,且python2和python3出来的接口有时候是不一样的,尽量避免使用round()函数吧

1 >>> round(1.1125) # 四舍五入,不指定位数,取整 2 1 3 >>> round(1.1135,3) # 取3位小数,由于3为奇数,则向下“舍” 4 1.113 5 >>> round(1.1125,3) # 取3位小数,由于2为偶数,则向上“入” 6 1.113 7 >>> round(1.5) # 无法理解,查阅一些资料是说python会对数据进行截断,没有深究 8 2 9 >>> round(2.5) # 无法理解 10 2 11 >>> round(1.675,2) # 无法理解 12 1.68 13 >>> round(2.675,2) # 无法理解 14 2.67 15 >>>

3、字符串输出
%s
%10s——右对齐,占位符10位
%-10s——左对齐,占位符10位
%.2s——截取2位字符串
%10.2s——10位占位符,截取两位字符串

1 >>> print("%s" % "hello world") # 字符串输出 2 hello world 3 >>> print("%20s" % "hello world") # 右对齐,取20位,不够则补位 4 hello world 5 >>> print("%-20s" % "hello world") # 左对齐,取20位,不够则补位 6 hello world 7 >>> print("%.2s" % "hello world") # 取2位 8 he 9 >>> print("%10.2s" % "hello world") # 右对齐,取2位 10 he 11 >>> print("%-10.2s" % "hello world") # 左对齐,取2位 12 he

4、 其他
字符串格式代码如下
(2)常用转义字符如下
二、format用法 “{:<填充><对齐><宽度><,><精度><类型>}”
相对基本格式化输出采用‘%’的方法,format()功能更强大,该函数把字符串当成一个模板,通过传入的参数进行格式化,并且使用大括号‘{}’作为特殊字符代替‘%’
使用方法由两种:b.format(a)和format(a,b)。
1、基本用法
(1)不带编号,即“{}”
(2)带数字编号,可调换顺序,即“{1}”、“{2}”
(3)带关键字,即“{a}”、“{tom}”

1 >>> print("{} {}".format("hello","world")) # 不带字段 2 hello world 3 >>> print("{0} {1}".format("hello","world")) # 带数字编号 4 hello world 5 >>> print("{0} {1} {0}".format("hello","world")) # 打乱顺序 6 hello world hello 7 >>> print("{1} {1} {0}".format("hello","world")) 8 world world hello 9 >>> print("{a} {tom} {a}".format(tom="hello",a="world")) # 带关键字 10 world hello world

2、进阶用法
(1)< (默认)左对齐、> 右对齐、^ 中间对齐、= (只用于数字)在小数点后进行补齐
(2)取位数“{:4s}”、"{:.2f}"等

1 >>> print("{} and {}".format("hello","world")) # 默认左对齐 2 hello and world 3 >>> print("{:10s} and {:>10s}".format("hello","world")) # 取10位左对齐,取10位右对齐 4 hello and world 5 >>> print("{:^10s} and {:^10s}".format("hello","world")) # 取10位中间对齐 6 hello and world 7 >>> print("{} is {:.2f}".format(1.123,1.123)) # 取2位小数 8 1.123 is 1.12 9 >>> print("{0} is {0:>10.2f}".format(1.123)) # 取2位小数,右对齐,取10位 10 1.123 is 1.12

3、多个格式化
"b" - 二进制。将数字以2为基数进行输出。 "c" - 字符。在打印之前将整数转换成对应的Unicode字符串。 "d" - 十进制整数。将数字以10为基数进行输出。 "o" - 八进制。将数字以8为基数进行输出。 "x" - 十六进制。将数字以16为基数进行输出,9以上的位数用小写字母。 "e" - 幂符号。用科学计数法打印数字。用"e"表示幂。 "g" - 一般格式。将数值以fixed-point格式输出。当数值特别大的时候,用幂形式打印。 "n" - 数字。当值为整数时和"d"相同,值为浮点数时和"g"相同。不同的是它会根据区域设置插入数字分隔符。 "%" - 百分数。将数值乘以100然后以fixed-point("f")格式打印,值后面会有一个百分号。
1 >>> print("{0:b}".format(3)) 2 11 3 >>> print("{:c}".format(20)) 4 5 >>> print("{:d}".format(20)) 6 20 7 >>> print("{:o}".format(20)) 8 24 9 >>> print("{:x}".format(20)) 10 14 11 >>> print("{:e}".format(20)) 12 2.000000e+01 13 >>> print("{:g}".format(20.1)) 14 20.1 15 >>> print("{:f}".format(20)) 16 20.000000 17 >>> print("{:n}".format(20)) 18 20 19 >>> print("{:%}".format(20)) 20 2000.000000% 21 >>>

- 上一篇: BYTES与十六进制表示的相互转换
- 下一篇: python格式化输出