python 输出特定字符串后面的数字
问题是这样的,我想记录文本的每一行的特定字符串后面的数字,假定文本的一行内容如下‘enc:0.088452ms,cpu:0.004dec:0.020126ms,cpu:0...
问题是这样的,我想记录文本的每一行的特定字符串后面的数字,假定文本的一行内容如下‘enc :0.088452 ms,cpu: 0.004 dec :0.020126 ms,cpu: 0.001’ 我想把‘cpu: ’后面的浮点数字用浮点保存下来。我本来写的代码是:
p = re.compile(r'cpu:\s*\d*\.\d*')
f2 = open('time.txt','r').readline()
print p.findall(f2)
输出为:
['cpu: 0.004', 'cpu: 0.001']
第一,如何用正则把前面的'cpu: '(冒号后2个空格)去掉只剩数字。我本来想用(?<=cpu:/s*)/d/./d的 好像不行 求指教
第二,是不是直接用float()函数对字符串强转就行了 展开
p = re.compile(r'cpu:\s*\d*\.\d*')
f2 = open('time.txt','r').readline()
print p.findall(f2)
输出为:
['cpu: 0.004', 'cpu: 0.001']
第一,如何用正则把前面的'cpu: '(冒号后2个空格)去掉只剩数字。我本来想用(?<=cpu:/s*)/d/./d的 好像不行 求指教
第二,是不是直接用float()函数对字符串强转就行了 展开
推荐于2018-03-20
展开全部
加个零宽断言就行了,python的零宽断言不支持长度不固定的表达式,所以需要将\s*移动到括号外边,用float()函数对数据进行处理就行了,float()函数可以处理字符串中的\s*等字符。
p = re.compile('(?<=cpu:)\s*\d*\.\d*')
f2 = open('time.txt','r').readline()
print list(map(float,p.findall(f2)))
结果如下,我用的是python3,所以print函数有一点点小变化。
>>> f2 = 'enc :0.088452 ms,cpu: 0.004 dec :0.020126 ms,cpu: 0.001'
>>> p = re.compile('(?<=cpu:)\s*\d*\.\d*')
>>> print(list(map(float,p.findall(f2))))
[0.004, 0.001]
>>>
p = re.compile('(?<=cpu:)\s*\d*\.\d*')
f2 = open('time.txt','r').readline()
print list(map(float,p.findall(f2)))
结果如下,我用的是python3,所以print函数有一点点小变化。
>>> f2 = 'enc :0.088452 ms,cpu: 0.004 dec :0.020126 ms,cpu: 0.001'
>>> p = re.compile('(?<=cpu:)\s*\d*\.\d*')
>>> print(list(map(float,p.findall(f2))))
[0.004, 0.001]
>>>
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询