gpt4 book ai didi

python - 通过 strip() 有效地使用元组

转载 作者:太空宇宙 更新时间:2023-11-03 13:40:54 27 4
gpt4 key购买 nike

考虑与内置方法 str.startswith() 一起使用的基本 tuple:

>>> t = 'x','y','z'
>>> s = 'x marks the spot'
>>> s.startswith( t )
True

str.strip() 中使用元组时似乎需要一个循环:

>>> for i in t: s.strip(i)
...
' marks the spot'
'x marks the spot'
'x marks the spot'

这可能看起来很浪费;有没有更有效的方法来使用 str.strip() 的元组项? s.strip(t) 似乎合乎逻辑,但事实并非如此。

最佳答案

剥离字符串与测试字符串是否以给定文本开头是一个非常不同的用例,因此这些方法在处理输入的方式上存在重大差异。

str.strip() 接受一个字符串,它被视为一组 字符;字符串中的每个字符都将被删除;只要字符串开头或结尾的字符是该集合的成员,该开始或结束字符就会被删除,直到开始和结束没有给定集合中的任何字符。

如果你有一个元组,将它连接成一个字符串:

s.strip(''.join(t))

或将其作为字符串文字传入:

s.strip('xyz')

请注意,这与对每个单独的元组元素使用 str.strip() 有一些不同的意思!

比较:

>>> s = 'yxz_middle_zxy'
>>> for t in ('x', 'y', 'z'):
... print(s.strip(t))
...
yxz_middle_zxy
xz_middle_zx
yxz_middle_zxy
>>> print(s.strip('xyz'))
_middle_

即使您将 str.strip() 调用链接到单个字符,它仍然不会产生相同的输出,因为 str.strip() 调用:

>>> for t in ('x', 'y', 'z'):
... s = s.strip(t)
...
>>> print(s)
xz_middle_zx

因为当这些字符被剥离时,字符串从未以 xz 开始或结束; x 只在开头和结尾结束,因为 y 字符在下一步中被删除。

关于python - 通过 strip() 有效地使用元组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31393631/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com