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()函数对字符串强转就行了
展开
 我来答
匿名用户
推荐于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]
>>>
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式