在做一个小的格式化输出的时候出现了问题:无论怎么排,汉字都无法很顺利地被居中,尤其是汉字和英文或者数字在一起时,更是一团糟。
python有内置的字符串方法str.center(x),可以让字符串以i的长度输出并居中。
但是!
但是!
但是!
在计算字符串长度时候默认是ascii的长度,也就是一个字符长度为1。
这显然行不通,因为一个中文占据2长度!中文符号亦然。
所以你要是想让 x=‘居中juzhong’ 这个字符串居中,你用str.center(len(x))的时候,就不能达到目的,原因是 len(x)=9 而不是实际上的11,输出的结果那自然是相当糟糕的。于是我写了一个函数,可以读取正确的字符串长度:
def lenCN(n):
#遇到非英文,自动二倍长度。
n=list(n)
stl=0
for x in n :
if x in string.printable:
stl +=1
else :
stl+=2
return stl
这样字符串的正确长度就可以读取了,但是这对于顺利进行居中排版还是不够的。正确的做法应该是:用这个函数读取某项所有单位的实际长度(比如‘姓名’),求出其中最大值,(比如‘爱新觉罗狗蛋’,为12),再加上为了美观考虑的一些空长度(随意,比如4)。然后让所有的姓名单位输出时用 print(x.center(12+4))即可。
有的时候,这样的输出也依然无法做到居中(奇数偶数空格的问题)。
这个时候,可以使用我写的这个小函数来完成。
def merg(x,y):
a=int((最大长度列表[项目名]-checkCN(当前项))/2)
b=int(((最大长度列表[项目名]-checkCN(当前项))/2)
if a+b != ((最大长度列表[项目名]-checkCN(当前项)))) :
b+=1
#防止出现奇数项的情况
return(a,b,)
def getmerg(x,y):
y=' '*merg(x,y)[0]+y+' '*merg(x,y)[1]
return y
一定可以达到目的。