我有一个如下字符串:
/cvmfs/atlas.cern.ch/repo/sw/ASG/AnalysisTop/2.0.24/RootCore
如何从此字符串中提取“2.0.24”?我不确定如何使用斜杠拆分字符串(为了提取结果列表的倒数第二个元素),我不确定这是否是一个好方法。我现在所拥有的是:
"/cvmfs/atlas.cern.ch/repo/sw/ASG/AnalysisTop/2.0.24/RootCore".split("/RootCore")[0].split("AnalysisTop/")[1]
答案 0 :(得分:7)
'/cvmfs/atlas.cern.ch/repo/sw/ASG/AnalysisTop/2.0.24/RootCore'.split('/')[-2]
答案 1 :(得分:6)
你也可以这样做:
import os
x = "/cvmfs/atlas.cern.ch/repo/sw/ASG/AnalysisTop/2.0.24/RootCore"
os.path.split(os.path.split(x)[0])[1]
结果
'2.0.24'
答案 2 :(得分:4)
根据/
符号进行拆分,然后打印最后一个索引。
>>> x = "/cvmfs/atlas.cern.ch/repo/sw/ASG/AnalysisTop/2.0.24/RootCore"
>>> y = x.split('/')
>>> y[-2]
'2.0.24'
答案 3 :(得分:0)
跨平台解决方案:
import os
'/cvmfs/atlas.cern.ch/repo/sw/ASG/AnalysisTop/2.0.24/RootCore'.split(os.path.sep)[-2]
答案 4 :(得分:-1)
path = "/cvmfs/atlas.cern.ch/repo/sw/ASG/AnalysisTop/2.0.24/RootCore"
path_dirs = path.split("/")
>>>> path_dirs
>>>> ['', 'cvmfs', 'atlas.cern.ch', 'repo', 'sw', 'ASG', 'AnalysisTop', '2.0.24', 'RootCore']
>>>> print path_dirs[-2]
>>>> '2.0.24'
答案 5 :(得分:-1)
import re
str1 = "/cvmfs/atlas.cern.ch/repo/sw/ASG/AnalysisTop/2.0.24/RootCore"
t = re.findall("[0-9][.]*",str1)
print ("".join(t))
您可以使用regex
- findall
方法。 t
会返回一个列表,因此请使用join()
。
输出;
>>>
2.0.24
>>>
# print (t)
>>>
['2.', '0.', '2', '4']
>>>