起因:
黑马程序员的python零基础教学中框架搭建的学习视频中老师做了一个名片管理系统,其中名片是以字典的形式存储,关于名片有一个显示全部的操作,是将字典中的内容像表格一样的格式输出。
教程里采用的操作:
if card_list: ? ? ? ? # card_list为存储字典名片的列表
? ? ? ? # 打印表头和分割线
? ? ? ? for name in ["姓名", "电话", "QQ", "邮箱"]:
? ? ? ? ? ? print(name, end="\t\t")
? ? ? ? print("")
? ? ? ? print("=" * 50)
? ? ? ? for dicts in card_list:
? ? ? ? ? ? print("%s\t\t%s\t\t%s\t\t%s\t\t" % (dicts["name"],
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? dicts["phone"],
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? dicts["qq"],
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? dicts["email"]))
但是在实际展示结果中会出现不对齐的结果
?
分析:
原代码中在每个输出后都添加两个制表符,但是输入的字符串长度没有限制,短的输入只占一个制表符,长的会占两、三个。
已知一个制表符为四个空格,根据输出内容的格式,也可以看出带制表符输出的规律: 第一个制表符\t比较特殊,会根据前面输入的格式来决定,如果不满四个空格,则会补满四个空格,刚好四个空格则会再添四个空格。第二个\t则是直接再加四个空格。
要解决需要使用能固定输入格式的方式:
字符串方法format
该方式将字符串中要替换的字符用{}括起
例:
>>> "{}, {} and {}".format("first","second","third") ? ?# 自动编号
'first, second and third'
>>> "{3} {0} {2} {1} {3} {0}".format("be","not","or","to") ? ?# 手动编号
'to be or not to be'
>>> "{foo} {} {bar} {}".format(1,2,foo = 3,bar = 4) ? ?# 字段替换
'3 1 4 2'
其中字段替换中: 字段!+转化标志 ? ?可以控制输出类型 字段:+ 填充/宽度/分隔符/格式
例:
>>> print("{pi!s} {pi!r} {pi!a}".format(pi="π"))
π 'π' '\u03c0'
>>> print('{a:x^30,.2f}'.format(a=8848))
xxxxxxxxxxx8,848.00xxxxxxxxxxx
其中: 首位x——以x填充 ^、>、<——填充方式居中、左填充、右填充 30——宽度 ,——千位分割符 .2f——小数点后保留二位的小数
改进方案:
改进后代码:
if card_list:
? ? ? ? # 打印表头和分割线
? ? ? ? print("{:^4}{:^12}{:^12}{:^24}".format("name", "phone", "qq", "email")) ? ?#居中显示,依次分配相应的宽度
? ? ? ? print("=" * 50)
? ? ? ? for dicts in card_list:
? ? ? ? ? ? print("{:^4}{:^12}{:^12}{:^24}".format(dicts["name"],
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?dicts["phone"],
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?dicts["qq"],
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?dicts["email"]))
改进后输出:
|