问题描述
问题
products = [["iphone", 6888], ["MacPro", 14800], ["小米6", 2499], ["Coffee", 31], ["Book", 60], ["Nike", 699]]
将列表中的数据按图中格式对齐
最初代码:
products = [["iphone", 6888], ["MacPro", 14800], ["小米6", 2499], ["Coffee", 31], ["Book", 60], ["Nike", 699]]
print("------\t商品格式\t------")
for i in range(len(products)):
print(i,"\t", products[i][0], "\t", products[i][1])
最初格式
原因
中文1个字符的宽度 = 2个ASCII符号的宽度 。 若有两字符串度相同(len函数的返回值),但如果其中一个字符串中含有中文,那他们的长度就不同。
string1 = "abcdefg"
string2 = "abcde一二"
print(len(string1))
print(len(string2))
print("*%10s*" % string1)
print("*%10s*" % string2)
解决方法一
定义一个函数,遇到中文便自动调整输出的格式中规定的长度
代码:
def pad_len(string, length):
return length - len(string.encode('GBK')) + len(string)
products = [["iphone", 6888], ["MacPro", 14800], ["小米6", 2499], ["Coffee", 31], ["Book", 60], ["Nike", 699]]
print("---- 商品格式 ----")
for i in range(len(products)):
print("{0:<{len1}}\t{1:<{len2}}\t{2:<{len3}}".format(i, products[i][0], products[i][1], len1=2,
len2 = pad_len(products[i][0], 10), len3 = 10))
格式
解决方法二 (wrong 只是巧合)
不知道原理, 当字符串中只有两个中文字符时 “\t” 会使两字符串对齐 比如一开始举的例子
string1 = "abcdefg"
string2 = "abcde一二"
print(len(string1))
print(len(string2))
print("*\t%10s\t*" % string1)
print("*\t%10s\t*" % string2)
但当一字符串中中文字符大于两个时,就对不齐了。
string1 = "abcdefg"
string2 = "abcd一二三"
print(len(string1))
print(len(string2))
print("*\t%10s\t*" % string1)
print("*\t%10s\t*" % string2)
代码
products = [["iphone", 6888], ["MacPro", 14800], ["小米6", 2499], ["Coffee", 31], ["Book", 60], ["Nike", 699]]
print("------\t商品格式\t------")
for i in range(len(products)):
print(i, end='\t')
print(products[i][0], end='\t')
print(products[i][1], end='\n')
格式
参考文章
解决方法一: Python中英文对齐终极解决方案
---------------- 更新 ------------------------ 看到了大佬的文章, 很有用!!! python str.format与制表符\t关于中文对齐的细节问题
|