如何删除字符串中某个字符后的所有内容?

时间:2013-07-26 21:37:08

标签: python string character python-3.3

如何删除python中字符串的某个字符后的所有内容?例如,我有一个包含文件路径和一些额外字符的字符串。如何在.zip之后删除所有内容?我已尝试rsplitsplit,但在删除多余字符时均未包含.zip。

有什么建议吗?

5 个答案:

答案 0 :(得分:15)

只需获取拆分的第一部分,然后再添加'.zip'

s = 'test.zip.zyz'
s = s.split('.zip', 1)[0] + '.zip'

或者您可以使用切片,这是一个解决方案,您无需将'.zip'添加回结果(4来自len('.zip')):

s = s[:s.index('.zip')+4]

或使用正则表达式的另一种选择:

import re
s = re.match(r'^.*?\.zip', s).group(0)

答案 1 :(得分:11)

str.partition

>>> s='abc.zip.blech'
>>> ''.join(s.partition('.zip')[0:2])
'abc.zip'
>>> s='abc.zip'
>>> ''.join(s.partition('.zip')[0:2])
'abc.zip'
>>> s='abc.py'
>>> ''.join(s.partition('.zip')[0:2])
'abc.py'

答案 2 :(得分:5)

使用切片:

s = 'test.zip.xyz'
s[:s.index('.zip') + len('.zip')]
=> 'test.zip'

并且很容易将上面的内容打包成一个小帮手函数:

def removeAfter(string, suffix):
    return string[:string.index(suffix) + len(suffix)]

removeAfter('test.zip.xyz', '.zip')
=> 'test.zip'

答案 3 :(得分:1)

您可以使用re模块:

import re
re.sub('\.zip.*','.zip','test.zip.blah')

答案 4 :(得分:1)

我认为为此创建一个简单的lambda函数很容易。

mystrip = lambda s, ss: s[:s.index(ss) + len(ss)]

可以像这样使用:

mystr = "this should stay.zipand this should be removed."
mystrip(mystr, ".zip") # 'this should stay.zip'