今天自己写字符串对齐输出时用到str.ljust()函数
但是它有个问题有个问题
当原字符串中出现中文字符时
给它规定的字符串宽度将不会准确显示
原因很简单,英文字符“b”和汉字“三”或者是“二”、“一”都会被视为一个字符——但显然,
屏幕显示的时候英文字符和汉字字符所占用的宽度是不一样的
为了解决这个问题,我自己写了一个函数集
def count_str(old_str):
return (len(old_str.encode())-len(old_str))//2+len(old_str)
def left_align(old_str,length,indent=0,strfill=' '):
return indent*' '+old_str+strfill*((length-count_str(old_str))//count_str(strfill))
def right_align(old_str,length,strfill=' '):
return strfill*((length-count_str(old_str))//count_str(strfill))+old_str
def center_align(oldstr,length,strfill=' '):
count = ((length-count_str(oldstr))//2)//count_str(strfill)
return strfill*count+oldstr+strfill*count
其中的主要原理就是count_str()函数的字符串长度计数
利用utf-8编码里中文以及中文字符比英文以及英文字符还有数字多两个字节这一点
准确识别出中文字符的个数并计算相应的宽度
以此来准确识别字符串显示宽度
并让left_align(),right_align(),center_align()进行精准对齐
其中left_align()还支持缩进以便更进行分级输出
所有的strfill都可以使用非单一字符串进行补齐
虽然可能会使整体长度跟预设长度不符
毕竟有些数的计算无法整除
同样的,center_align()也可能出现这样的问题
目前暂无解决办法,一个不算bug的bug
ps:left_align(‘点个赞吧’,48,4,strfill=‘啊~~~’)
——人生第一篇学习博客