Skip to Content
Pythonデータサイエンスハンドブック ―Jupyter、NumPy、pandas、Matplotlib、scikit-learnを使ったデータ分析、機械学習
book

Pythonデータサイエンスハンドブック ―Jupyter、NumPy、pandas、Matplotlib、scikit-learnを使ったデータ分析、機械学習

by Jake VanderPlas, 菊池 彰
May 2018
Intermediate to advanced
556 pages
13h 21m
Japanese
O'Reilly Japan, Inc.
Content preview from Pythonデータサイエンスハンドブック ―Jupyter、NumPy、pandas、Matplotlib、scikit-learnを使ったデータ分析、機械学習
210
3
章 
pandas
を使ったデータ操作
3.13
 ハイパフォーマンス
pandas
eval()
query()
これまでに説明したように、
PyData
が強力であるのは、
NumPy
のベクトル化
/
ブロードキャス
ト操作および
pandas
のグループ化などの直感的な構文による基本操作を、
C
言語で書かれたコー
ドで実行する能力を基盤にしています。こうした抽象化は多くの一般的ユースケースで効率的かつ
効果的ですが、しばしば一時的な中間オブジェクトを生成し、計算時間とメモリ使用に過大なオー
バーヘッドを引き起こす可能性があります。
2014
1
月リリースにリリースされた)
pandas
バージョン
0.13
から、コストのかかる中間配列
の割り当てを行わずに
C
言語コードの実行速度で直接操作するための実験的機能、
Numexpr
ライ
ブラリ(
https://github.com/pydata/numexpr
)の
eval()
関数と
query()
関数を提供しています。こ
では、どのように使うのか、使うための考え方について見てみましょう。
3.13.1
query()
eval()
の必要性:複合表現
既に見てきたように、
NumPy
pandas
は高速なベクトル化操作をサポートしています。例えば、
2
つの配列で、要素ごとの加算は次のように実行します。
In[1]: import numpy as np
rng = np.random.RandomState(42)
x = rng.rand(1000000)
y = rng.rand(1000000) ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Start your free trial

You might also like

Pythonデータサイエンスハンドブック 第2版 ―Jupyter、NumPy、pandas、Matplotlib、scikit-learnを使ったデータ分析、機械学習

Pythonデータサイエンスハンドブック 第2版 ―Jupyter、NumPy、pandas、Matplotlib、scikit-learnを使ったデータ分析、機械学習

Jake VanderPlas, 菊池 彰
初めてのGraphQL ―Webサービスを作って学ぶ新世代API

初めてのGraphQL ―Webサービスを作って学ぶ新世代API

Eve Porcello, Alex Banks, 尾崎 沙耶, あんどうやすし

Publisher Resources

ISBN: 9784873118413Other