从嵌套字典生成列表的Pythonic方法

2024-09-28 22:46:13 发布

您现在位置:Python中文网/ 问答频道 /正文

在python2.7中,我有一个嵌套字典,其中包含一些引号数据,我想从中生成一个成功构造引号的列表。目前,我是这样做的:

result = []
for nameStr, nameData in dataTbl.iteritems():
    for valueDate, record in nameData.iteritems():
        quote = histRecordToQuote(securitiesDict = securitiesDict,
                                  nameStr        = nameStr,
                                  valueDate      = valueDate,
                                  record         = record)
        if quote:
            result.append(quote)

有没有更像Python的方法?我有一个预感,我们可以做得更快或更清楚的清单理解。函数histRecordToQuote()在由于数据错误而无法构造引号时返回None。你可以建议一个不同的签名,我很乐意重写它以获得更清晰/更快的代码。你知道吗

非常感谢。你知道吗

编辑

字典结构示例:

{'IBM':  {'20140215':2.53, '20140216':2.55},
 'MSFT': {'20140213':2.45, '20140216':0.},
 'AMZN': {'20140212':0., '20140214':2.59}}

参数securitiesDict是外部的,它是在histRecordToQuote()内部构造Quote类所必需的。你知道吗

来自histRecordToQuote()的输出将返回0-price记录的None,并从其余记录构造有效的Quote。你知道吗

Quote('IBM', '20140215', 2.53)
Quote('IBM', '20140216', 2.55)
Quote('MSFT', '20140213', 2.45)
None
Quote('AMZN', '20140214', 2.59)
None

我的最终输出需要是有效引号的列表:

[Quote('IBM', '20140215', 2.53),
Quote('IBM', '20140216', 2.55),
Quote('MSFT', '20140213', 2.45),
Quote('AMZN', '20140214', 2.59)]

Tags: 数据none列表字典recordibm引号quote
1条回答
网友
1楼 · 发布于 2024-09-28 22:46:13

您可以通过嵌套理解实现相同的效果:

[ quote for quote in
    (histRecordToQuote(securitiesDict = securitiesDict,
                       nameStr        = nameStr,
                       valueDate      = valueDate,
                       record         = record)
      for nameStr, nameData in dataTbl.iteritems()
        for valueDate, record in nameData.iteritems())
    if quote ]

相关问题 更多 >