[{"length": 1000, "speed": 100}, {"length": 1010, "speed": 110}, ・・・・・]
上記のような同じキーを持つ辞書がリスト内にあるとき、"length"の値の最大値を高速で求めたいのですが、良い方法はあるでしょうか?
for文とpandasでは試してみました。
ちなみにリスト長(辞書の数)は変わるので、毎回DataFrameやfor in raw_dataを行っています。
リスト長は5~20ほどです
python
1import time 2import pandas as pd 3 4def calc_list(raw_data): 5 for i in range(100000): 6 length = [] 7 for i in raw_data: 8 length.append(i["length"]) 9 max_length = max(length) 10 11def calc_pd(raw_data): 12 for i in range(100000): 13 df = pd.DataFrame(raw_data) 14 max_length = df["length"].max() 15 16if __name__ == '__main__': 17 raw_data = [] 18 length = 1000 19 speed = 100 20 for i in range(10): 21 raw_data.append({"length": length + i*10, "time": speed + i*10}) 22 23 start = time.time() 24 calc_list(raw_data) 25 print(time.time() - start) # 0.1189秒 26 27 start = time.time() 28 calc_pd(raw_data) 29 print(time.time() - start) # 60秒
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。