[英]Extracting floating point numbers in a string using regex
我有以下字符串列表
List = ['A = -25.47 dBm' , 'B = -47.35 dBm' , 'A = -26.54 dBm' , 'B = -32.35 dBm', 'A = 27.95 dBm' , 'B = -64.11 dBm' , 'A = -45.11 dBm' , 'B = -18.67 dBm']
我想提取 A 的值制作一個列表,B 的值並制作一個列表
我已經嘗試了以下
#First I joined the data into a string
S = ' '.join(List)
re.findall(r"A = ([-+]?\d*\.\d+|\d+) dBm" , S)
這似乎不起作用
預期結果
A_list = [-25.47,-26.54, 27.95,-45.11]
B_list = [-47.35,-32.35,-64.11,-18.67]
您可以使用re
和collections.defaultdict
:
import re, collections
l = ['A = -25.47 dBm' , 'B = -47.35 dBm' , 'A = -26.54 dBm' , 'B = -32.35 dBm', 'A = 27.95 dBm' , 'B = -64.11 dBm' , 'A = -45.11 dBm' , 'B = -18.67 dBm']
d = collections.defaultdict(list)
for i in l:
a, b = re.findall('^\w+|[\-\d\.]+', i)
d[a].append(float(b))
A_list, B_list = d['A'], d['B']
輸出:
[-25.47, -26.54, 27.95, -45.11]
[-47.35, -32.35, -64.11, -18.67]
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.