('Time ': '2017-12-01T13:54:04', 'Energy [kWh]': '0.01') 语法不是有效的 Python。假设您实际上想要一个字典列表,执行该转换并不难。
您首先需要获取时间戳,以便它可以与其他每个项目组合,然后您可以将其从 dict 中删除,以便更轻松地将剩余项目复制到新结构中。请注意,这会修改传递给函数的原始字典。如果您不希望这样做,您可以复制传入的 dict,或者在将数据复制到新结构的循环中放置 if 测试,以便跳过时间项。
def convert(old):
time_key = 'Time '
# Save the time
time_item = (time_key, old[time_key])
# Add remove it
del old[time_key]
# Copy remaining items to new dicts and save them in a list
return [dict([time_item, item]) for item in old.items()]
row = {
'Time ': '2017-12-01T13:54:04',
'Energy [kWh]': '0.01',
'Voltage [V]': '221.64',
'Current [A]': '0.08',
}
new_data = convert(row)
for d in new_data:
print(d)
输出
{'Time ': '2017-12-01T13:54:04', 'Energy [kWh]': '0.01'}
{'Time ': '2017-12-01T13:54:04', 'Voltage [V]': '221.64'}
{'Time ': '2017-12-01T13:54:04', 'Current [A]': '0.08'}
如果您不想改变或复制原始字典,请按照以下方法操作:
def convert(old):
time_key = 'Time '
# Save the time
time_item = (time_key, old[time_key])
# Copy other items to new dicts and save them in a list
return [dict([time_item, (key, val)])
for key, val in old.items() if key != time_key]
请注意,这样做效率较低,因为它必须测试每个键以确保它不是时间键。
要将数据保存在OrderedDicts 的列表中,我们需要稍微改变一下逻辑。我们还需要正确创建OrderedDicts,以便项目按所需顺序排列。
from collections import OrderedDict
from pprint import pprint
def convert(row):
time_key = 'Time '
time_value = row[time_key]
new_data = []
for key, val in row.items():
if key == time_key:
continue
new_data.append(OrderedDict(Device=key, Measure=val, Time=time_value))
return new_data
row = {
'Time ': '2017-12-01T13:54:04', 'Energy [kWh]': '0.01',
'Voltage [V]': '221.64', 'Current [A]': '0.08'
}
new_data = convert(row)
pprint(new_data)
输出
[OrderedDict([('Device', 'Energy [kWh]'),
('Measure', '0.01'),
('Time', '2017-12-01T13:54:04')]),
OrderedDict([('Device', 'Voltage [V]'),
('Measure', '221.64'),
('Time', '2017-12-01T13:54:04')]),
OrderedDict([('Device', 'Current [A]'),
('Measure', '0.08'),
('Time', '2017-12-01T13:54:04')])]