15

python - 如何在python中字符串的某个字符之后删除所有内容?例如,我有一个包含文件路径和一些额外字符的字符串。我将如何删除 .zip 之后的所有内容?我试过rsplitand split,但在删除多余字符时都没有包含 .zip 。

有什么建议么?

4

5 回答 5

19

只需获取拆分的第一部分,然后添加'.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)
于 2013-07-26T21:41:00.210 回答
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'
于 2013-07-26T21:47:51.593 回答
6

使用切片:

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'
于 2013-07-26T21:39:12.450 回答
1

您可以使用该re模块:

import re
re.sub('\.zip.*','.zip','test.zip.blah')
于 2013-07-26T21:44:05.807 回答
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'
于 2013-07-26T21:50:26.693 回答