python - 如何在python中字符串的某个字符之后删除所有内容?例如,我有一个包含文件路径和一些额外字符的字符串。我将如何删除 .zip 之后的所有内容?我试过rsplit
and split
,但在删除多余字符时都没有包含 .zip 。
有什么建议么?
python - 如何在python中字符串的某个字符之后删除所有内容?例如,我有一个包含文件路径和一些额外字符的字符串。我将如何删除 .zip 之后的所有内容?我试过rsplit
and split
,但在删除多余字符时都没有包含 .zip 。
有什么建议么?
只需获取拆分的第一部分,然后添加'.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)
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'
使用切片:
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'
您可以使用该re
模块:
import re
re.sub('\.zip.*','.zip','test.zip.blah')
我认为为此创建一个简单的 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'