python字符宽度_python怎么算出字符串的宽度

可能我说的不太清楚,现在我把代码和结果发出来,用的是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/

看来这个问题是无解了

其实我觉得你的这问题,思路是走错了。为什么我是等号的2个宽度,而ab只有1个宽度,是因为我是2个字节,而等号是1个字节。因此不如调整思路查看它们的字节数。在gbk编码下为2个字节,对于utf8为3个字节,这样应该可以解决你的问题。例如,可以通过如下的代码来实现:

d = u'我我ab'

for x in d:

x = x.encode('gbk')

print x, len(list(x))

>>>

我 2

我 2

a 1

b 1

之前假设你的系统使用的使用GBK编码,而且为python2。现在你已经说明是python3,那么我更新下我的答案:

ab = "我ab"

print '=' * len(list(ab))

>>> '='*len(list('我ab'))

'==='

>>> '='*len(list('ab'))

'=='

>>> '='*len(list('我'))

'='

那么看看这篇文章是否符合你的要求,http://blog.csdn.net/zhangxinrun/article/details/7526044

可以考虑使用全角的

(汉字本来设计就不是为了和英文的半角等宽的吧)

半角对比

=

全角

=

这个跟字体有关了吧,把编辑器换成等宽字体就好了

对比下面两段,length多长就打印多个少=

#coding=gb2312

a = '中文'

b = 'str'

ab = '中文str'

print len(a), len(b), len(ab)

#coding=utf-8

a = u'中文'

b = 'str'

ab = u'中文str'

print len(a.encode('gb2312')), len(b), len(ab.encode('gb2312'))

这个

len

打出的是他的长度,如果在Python3中都变成了Unicode,自然符合你的预期,CJK字符和拉丁字符都是长度为1,对于Python2而言,默认不是Unicode,而是某种编码(取决于你的文档使用的什么编码),而你encode等于是将Unicode编码成了某种编码(我没查看默认值了),所以长度变成了该字符在这个编码下所占字节数,你得到的长度就不符合你的预期了,解决方案是:

在代码文档上标明文档编码,例如

# -*- encoding: utf-8 -*-

一来告诉电脑,二来告诉自己。

在处理字符长度的时候需要decode对应编码,从而得到Unicode的码。这时候长度才满足你的需求。

在Python2上你试试:

# -*- encoding: utf-8 -*-

a = u'我'

b = u'ab'

ab = u'我ab'

print len(a), len(b), len(ab)

应该就符合你的预期了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值