最近の Python 開発についてよく知っている方は、データを操作するための新しいライブラリである Polars について聞いたことがあるでしょう。 pandas は長い間頼りになるライブラリでしたが、Polars は、特に大きなデータセットの処理に関して話題を呼んでいます。では、Polars にとって何が重要なのでしょうか?パンダとどう違うの?分解してみましょう。
Polars は、Rust (高速で最新のプログラミング言語) で構築された無料のオープンソース ライブラリです。 Python 開発者がより高速かつ効率的な方法でデータを処理できるように設計されています。これは、パンダが苦労する可能性のある非常に大規模なデータセットを扱うときに威力を発揮するパンダの代替手段と考えてください。
Pandas は何年も前から存在しており、多くの人が今でも愛用しています。しかし、データが大きくなり複雑になるにつれて、パンダにはいくつかの弱点が見え始めました。 Polars の作成者である Ritchie Vink は、これらの問題に気づき、より高速で効率的なものを作成することにしました。パンダの作成者であるウェス・マッキニーでさえ、「パンダについて私が嫌いな10のこと」というタイトルのブログ投稿で、特に大規模なデータセットの場合、パンダには何らかの改善が必要であることを認めました。
そこで、Polars が登場します。Polars は、パンダがビッグデータを処理する際に苦労する 2 つの点である、超高速かつメモリ効率を高めるように設計されています。
Polars は本当に速い。実際、いくつかのベンチマークでは、データのフィルタリングやグループ化などの一般的な操作を実行する場合、Polars は pandas よりも最大 5 ~ 10 倍高速 であることが示されています。この速度の違いは、大規模なデータセットを操作する場合に特に顕著です。
メモリに関しては、Polars の方がはるかに効率的です。パンダに比べて使用するメモリの量は約 5 ~ 10 分の 1です。つまり、メモリの問題が発生することなく、はるかに大規模なデータセットを操作できます。
Polars は 遅延実行 と呼ばれるものを使用します。これは、各操作を作成したときにすぐに実行されないことを意味します。代わりに、一連の操作が記述されるまで待機してから、それらをすべて一度に実行します。これにより、処理が最適化され、より高速に実行されます。一方、Pandas はすべての操作を即座に実行するため、大きなタスクの場合は遅くなる可能性があります。
Polars は、複数の CPU コアを同時に使用してデータを処理できるため、大きなデータセットの場合はさらに高速になります。 Pandas はほとんどがシングル スレッドです。つまり、一度に 1 つの CPU コアしか使用できないため、特に大規模なデータセットの場合、処理速度が遅くなります。
Polars が高速である理由はいくつかあります:
Rust と Apache Arrow の組み合わせにより、速度とメモリ使用量の点で Polars がパンダよりも優位になります。
Polars はビッグデータに最適ですが、pandas も依然としてその役割を果たしています。 Pandas は小規模から中規模のデータセットで非常にうまく機能し、非常に長い間存在しているため、大量の機能と巨大なコミュニティがあります。したがって、巨大なデータセットを扱っていない場合でも、パンダが最良の選択肢になる可能性があります。
ただし、データセットが大きくなるにつれて、pandas はより多くのメモリを使用して速度が低下する傾向があるため、そのような状況では Polars の方が良い選択肢となります。
次の場合は、Polars の使用を検討してください。
Polar と panda にはどちらもそれぞれの長所があります。小規模から中規模のデータセットを扱う場合、pandas は依然として優れたツールです。しかし、大規模なデータセットを扱っていて、より高速でメモリ効率の高いものが必要な場合は、Polars は間違いなく試してみる価値があります。 Rust と Apache Arrow のおかげでパフォーマンスが向上し、データ集約型のタスクに最適なオプションとなっています。
Python が進化し続けるにつれて、Polars がビッグデータを処理するための新しい goto ツールになる可能性があります。
コーディングを楽しんでいますか? ?
以上がPolars 対 Pandas Python におけるデータフレームの新時代?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。