如何将多行值读入字典中

问题描述 投票:0回答:1

我有file1格式

field1-name, initial-val, desc
field2-name, initial-val, desc
field2-name, initial-val, desc
end-group1

field1-name, inital-val, desc
end-group2

.....

我需要创建一个组字典,其中组作为键,字段列表作为值

group1: [(field1-name, initial-val, desc), (field2-name, inital-val, desc),(...)]
group2: [(field1-name, initial-val, desc)]

读取此文件并将其转换为组的最Python方式是什么。我的代码可以逐行读取并解析/存储值,但是想知道是否有更好的方法。

psedo-code
group = {}
with open(file, 'r') as f:
   for line in f:
      if line.startswith(r/end/):
          #extract group-name and create a tuple for field values
          group[group-name] = new_group
          new_group = []
          continue
      new_group.append(line)
python multiline
1个回答
0
投票

鉴于您的文件格式是混合格式,逐行读取文件是最合适的解决方案,需要一条条件语句来确定是追加到子列表还是创建新的dict条目:

group = {}
rows = []
with open(file, 'r') as f:
    for line in f:
        line = line.rstrip()
        if line.startswith('end-'):
            group[line.replace('end-', '', 1)] = rows
            rows = []
        elif line:
            rows.append(tuple(line.split(', ')))

group变为:

{'group1': [('field1-name', 'initial-val', 'desc'),
            ('field2-name', 'initial-val', 'desc'),
            ('field2-name', 'initial-val', 'desc')],
 'group2': [('field1-name', 'inital-val', 'desc')]}
© www.soinside.com 2019 - 2024. All rights reserved.