资源干货第一时间送达!
纯干货文章,容易口渴,但是耐心看完你绝对会有收获噢~
不知道小伙伴有没有遇到过字符串输出有格式要求的情况呢?今天小詹学习分享一波python的字符串格式化的方法。学以致用,首先我们得明确为什么要格式化字符串输出,以及在哪些场景可能会用的上?考虑到这个一百度就有很多,就不赘述啦。
今天的重点是如何基于python对字符串进行格式化输出?小詹先给出两种方法,再逐一按照实例介绍
方法一 % 格式符
基本形式:%[(name)][flags][width].[precision]typecode
(name) 可选,用于选择指定的key(与字典形式结合,选择指定的key,友情提醒,字典没有顺序的说法噢)
flags 可选,可供选择的值有: + - 空格 0
width 可选,占有宽度
.precision 可选,小数点后保留的位数(小詹友情提醒,整型d可是没有小数的说法噢)
typecode必选!
以下结合实例说明每个参数的概念和使用:
1. (name) 可选,用于选择指定的key,输出字典中指定的key对应的值,字典中没有顺序,只有键值对对应即可:
2.flags 可选,可供选择的值有:(通常与width结合)
+ 右对齐;正数前加正号,负数前加负号;
- 左对齐;正数前无符号,负数前加负号;
空格 右对齐;正数前加空格,负数前加负号;
0 右对齐;正数前无符号,负数前加负号;用0填充空白处
3.width 可选,占有宽度
这里结合2.3,以对比右对齐和左对齐为例;如下的age部分:
4. .precision 可选,小数点后保留的位数(小詹再次提醒,不要忘了整型无小数噢)
这里比较好懂,还是那句话为例,只不过得把key:age改成float类型!
细心的朋友会发现上述两句仅有一点之差噢!没错,第一个是没有‘.’,那么10代表的是【width】,为占位宽度;第二个有‘.’,代表【.precision】,为小数点个数
5.typecode 必选(哎哟喂!唯一一个必选!)表示获取对应类型的值并格式化到指定位置
s,获取传入对象的__str__方法的返回值,并将其格式化到指定位置
r,获取传入对象的__repr__方法的返回值,并将其格式化到指定位置
c,整数:将数字转换成其unicode对应的值,10进制范围为 0
o,将整数转换成 八 进制表示,并将其格式化到指定位置
x,将整数转换成十六进制表示,并将其格式化到指定位置
d,将整数、浮点数转换成 十 进制表示,并将其格式化到指定位置
e,将整数、浮点数转换成科学计数法,并将其格式化到指定位置(小写e)
E,将整数、浮点数转换成科学计数法,并将其格式化到指定位置(大写E)
f, 将整数、浮点数转换成浮点数表示,并将其格式化到指定位置(默认保留小数点后6位)
F,同上
g,自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是e;)
G,自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是E;)
%,当字符串中存在格式化标志时,需要用 %%表示一个百分号
这里用的最多应当是字符型‘s',整型'd',浮点数'f'~对应前边的age即可了解,不做重复举例啦~
这里来一个综合示例:(借用闹笑话那次的啦~)
方法二 format方式
基本形式:[[fill]align][sign][#][width][,][.precision][type]
fill 【可选】空白处填充的字符
align 【可选】对齐方式(需配合width使用)
sign 【可选】有无符号数字【同方法一的flags,仅+-0三种取值】
# 【可选】对于二进制、八进制、十六进制,如果加上#,会显示 0b/0o/0x,否则不显示
, 【可选】为数字添加分隔符,如:1,000,000
width 【可选】格式化位所占宽度
.precision 【可选】小数位保留精度
type 【可选】格式化类型,类似方法一,不重复叙述
这里是用格式化字符串的函数 str.format(),它增强了字符串格式化的功能。基本语法是通过 {} 和 : 来代替以前的 %。format 函数可以接受不限个参数,位置可以不按顺序。和第一种方法一样,以下结合实例说明每个参数的概念和使用:
1.fill 【可选】空白处填充的字符这里比第一种方式拓展性好,可以指定填充的字符
2.align 【可选】对齐方式(需配合width使用)
>,内容右对齐(默认)
^,内容居中
^,内容居中=,内容右对齐,将符号放置在填充字符的左侧,且只对数字类型有效。即使:符号+填充物+数字
3.width 【可选】格式化位所占宽度
以上三个参数结合起来使用较为频繁,例如下面是不同姿势的'我爱小詹'
4.# 【可选】对于二进制、八进制、十六进制,如果加上#,会显示 0b/0o/0x,否则不显示
b,将10进制整数自动转换成2进制表示然后格式化
c,将10进制整数自动转换为其对应的unicode字符
d,十进制整数
o,将10进制整数自动转换成8进制表示然后格式化;
x,将10进制整数自动转换成16进制表示然后格式化(小写x)
X,将10进制整数自动转换成16进制表示然后格式化(大写X)
下面以小詹的age举例,以二进制的15为例(才不告诉你小詹才15岁呢):
5. , 【可选】为数字添加分隔符,如:1,000,000
6. .precision 【可选】小数位保留精度【同方法一,整型无小数】
这里以小詹年薪salary为例哈哈,注意关键区别在{}内:
基本到这里,两种方法都学的差不多了,小伙伴们自己实操下肯定没啥问题。最后值得一提的是format方法中不一定要将所有值重复列,有重复的可以用类似字典键值对的形式存放。如下例,就用了num=15省去了重复列举15的过程:
领取专属 10元无门槛券
私享最新 技术干货