如何删除python中字符串的某个字符后的所有内容?例如,我有一个包含文件路径和一些额外字符的字符串。如何在.zip之后删除所有内容?我已尝试rsplit
和split
,但在删除多余字符时均未包含.zip。
有什么建议吗?
答案 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'