s = '种草 '
print(len(s))
s = s.strip()
print(len(s))两者的输出都是'4‘。这个空间似乎占用了2个字符,而且不能被条带()函数删除。这是一个中国空间,不能被条形函数移除。
发布于 2020-02-04 06:56:33
这不是通常的unicode空间。你可以这样把它移走。
s = '种草 '
print(len(s))
s = s.strip(u'\u200b').strip()
print(len(s))发布于 2020-02-04 06:52:06
strip从字符串的两端删除空格。
>>> s = '种草 '
>>> ord(s[-1])
8203
>>> ord(s[-2])
32
>>> ord(' ')
32这里的最后一个字符不是空格字符。最后一个角色是一个空格。
发布于 2020-02-04 07:40:13
也许,这不是一个好看的解决方案,但它将删除所有的不可打印和空白字符:
from itertools import takewhile
check = lambda c: not c.isprintable() or c.isspace()
result = s[len(tuple(takewhile(check, s))): -len(tuple(takewhile(check, reversed(s))))]
# OR to not waste memory for tuple
result = s[sum(1 for _ in takewhile(check, s)): -sum(1 for _ in takewhile(check, reversed(s)))]在这里,我使用itertools.takewhile()从字符串的开头获取所有不可打印(str.isprintable())和空格(str.isspace())字符。然后,使用len() (或sum()选项和列表理解),我得到了一些字符,并在字符串切片中使用这个数量作为开始索引。为了获得结束索引,我使用了相同的方法,但是使用了反向(reversed())字符串。
https://stackoverflow.com/questions/60051972
复制相似问题