リスト内包表記の効率を見つけようとしていますが、通常の関数操作よりもコストがかかるようです。誰か説明できますか?
def squares(values):
lst = []
for x in range(values):
lst.append(x*x)
return lst
def main():
t = timeit.Timer(stmt="lst = [x*x for x in range(10)]")
print t.timeit()
t = timeit.Timer(stmt="squares",setup="from __main__ import squares")
print t.timeit()
lst = [x*x for x in range(10)]
print lst
print squares(10)
----Output:---
2.4147507644
0.0284455255965
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
同じ出力の場合、通常の関数はリスト内包表記に比べて非常に短い時間で計算します。
リスト内包表記の方が効率的だと思いました。