繁体   English   中英

python 3删除字符串前后

[英]python 3 remove before and after on string

我有这个字符串/1B5DB40?full ,我想将其转换为1B5DB40

我需要删除?full和front /

我的网站在结尾处不会总是有?full ,因此即使没有“ ?full ,我也需要一些仍然可以工作的东西。

谢谢,希望这不会让您感到困惑:)

编辑:
我知道我可以在0和8处进行分割,但是1B5DB40可以更长或更短。 例如,它可能是/1B5DB4000?full/1B5

使用str.lstrip (删除前导/ )和str.split (删除?之后的最佳部分):

>>> '/1B5DB40?full'.lstrip('/').split('?')[0]
'1B5DB40'

>>> '/1B5DB40'.lstrip('/').split('?')[0]
'1B5DB40'

或使用urllib.parse.urlparse

>>> import urllib.parse
>>> urllib.parse.urlparse('/1B5DB40?full').path.lstrip('/')
'1B5DB40'
>>> urllib.parse.urlparse('/1B5DB40').path.lstrip('/')
'1B5DB40'

您可以使用lstriprstrip

>>> data.lstrip('/').rstrip('?full')
'1B5DB40'

这只只要你没有的人物作品ful? /在您要提取的部分中。

您可以使用正则表达式:

>>> import re

>>> extract = re.compile('/?(.*?)\?full')
>>> print extract.search('/1B5DB40?full').group(1)
1B5DB40
>>> print extract.search('/1Buuuuu?full').group(1)
1Buuuuu

那正则表达式呢?

import re
re.search(r'/(?P<your_site>[^\?]+)', '/1B5DB40?full').group('your_site')

在这种情况下,它匹配'/''?'之间'/'所有内容 ,但您可以根据自己的特定要求进行更改

>>> '/1B5DB40?full'split('/')[1].split('?')[0]
'1B5DB40'
>>> '/1B5'split('/')[1].split('?')[0]
'1B5'
>>> '/1B5DB40000?full'split('/')[1].split('?')[0]
'1B5DB40000'

如果找不到分隔符, Split将仅返回包含原始字符串的单个元素列表。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM