我正在尝试编写一个函数,该函数将接受一个字符串并返回一个字典,其中包含字符串中包含的所有数字以及它们开始的索引。
例如,字符串"1this is a 134 test15"
将生成字典{ 0:1, 11:134, 19:15 }
我已经看到许多使用正则表达式的类似问题的解决方案,这些问题非常适用于自己提取数字,但是我无法找到将这些数字与它们出现的索引相关联的方法。 / p>
是否可以使用正则表达式从字符串中提取此类信息,或者是否有不同的方法可以更适合此类应用程序。
答案 0 :(得分:7)
In [44]: strs="1this is a 134 test15"
In [45]: {m.start(0):int(m.group(0)) for m in re.finditer("\d+", strs)}
Out[45]: {0: 1, 11: 134, 19: 15}
答案 1 :(得分:4)
>>> import re
>>> text = "1this is a 134 test15"
>>> d = dict((m.start(), int(m.group())) for m in re.finditer(r'\d+', text))
>>> d
{0: 1, 19: 15, 11: 134}
答案 2 :(得分:1)
正则表达式MatchObject
的{{3}}方法将提供当前匹配的字符串偏移量。
答案 3 :(得分:0)
如果您正在寻找功能,我希望这可能有用。肯定有一种更简单的方法。然而,这就是我的成果。我尽我所能:)
def function(string,dic={},p=0):
if len(string)==0:
return dic
else:
i=0
if string[0] in '1234567890':
while string[i] in '0123456789':
i+=1
p+=1
dic[p-len(string[:1])]=int(string[:i])
string=string[i:]
return function(string,dic,p)
else:
p+=1
return function(string[1:],dic,p)