我想知道是否需要两个列表推导来返回 set / dict / list 的有序对以及 set / dict / list 中的值的总和。这是我的意思的一个例子:
>>> l = ['abc', 'd', 'efgh', 'ij']
>>> {i: len(i) for i in l}, sum(len(i) for i in l)
({'efgh': 4, 'abc': 3, 'ij': 2, 'd': 1}, 10)
有没有比重复for i in l
理解更好/更pythonic的方式来写这个?
更新:
我问这个问题是因为我在想写一个特定的最好的方法lambda
;IE
>>> l = ['abc', 'd', 'efgh', 'ij']
>>> dict_value = lambda l: ({i: len(i) for i in l}, sum(len(i) for i in l))
>>> dict_value(l)
({'efgh': 4, 'abc': 3, 'ij': 2, 'd': 1}, 10)
我问这个问题是因为我不是len()
用来计算我想要的值,而是一个昂贵的计算。如果我定义辅助方法而不是 lambda 来完成工作,那么下面关于 for 循环的点确实可以解决问题。