可能我说的不太清楚,现在我把代码和结果发出来,用的是python3,原始字符串ab可能是任何字符,我要实现的是等号和上面的字符串长度一样
a = '我'
b = 'ab'
ab = '我ab'
print(len(a), len(b), len(ab), len('='))
print(ab)
print('='*len(ab))
print(len(a.encode()), len(b.encode()), len(ab.encode()), len('='.encode()))
print(ab)
print('='*len(ab.encode()))
结果是
1 2 3 1
我ab
===
3 2 5 1
我ab
=====
最后发现了这篇文章
https://lichifeng.com/truncate-strings-by-screen-width-in-python/
看来这个问题是无解了
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
其实我觉得你的这问题,思路是走错了。为什么我是等号的2个宽度,而ab只有1个宽度,是因为我是2个字节,而等号是1个字节。因此不如调整思路查看它们的字节数。在gbk编码下为2个字节,对于utf8为3个字节,这样应该可以解决你的问题。例如,可以通过如下的代码来实现:
之前假设你的系统使用的使用GBK编码,而且为python2。现在你已经说明是python3,那么我更新下我的答案:
那么看看这篇文章是否符合你的要求,http://blog.csdn.net/zhangxinrun/article/details/7526044
可以考虑使用全角的
=(汉字本来设计就不是为了和英文的半角等宽的吧)半角对比
全角
这个跟字体有关了吧,把编辑器换成等宽字体就好了
对比下面两段,length多长就打印多个少=
这个
len打出的是他的长度,如果在Python3中都变成了Unicode,自然符合你的预期,CJK字符和拉丁字符都是长度为1,对于Python2而言,默认不是Unicode,而是某种编码(取决于你的文档使用的什么编码),而你encode等于是将Unicode编码成了某种编码(我没查看默认值了),所以长度变成了该字符在这个编码下所占字节数,你得到的长度就不符合你的预期了,解决方案是:在代码文档上标明文档编码,例如
# -*- encoding: utf-8 -*-一来告诉电脑,二来告诉自己。在处理字符长度的时候需要decode对应编码,从而得到Unicode的码。这时候长度才满足你的需求。
在Python2上你试试:
应该就符合你的预期了。