[解決済み】Pandasでブールインデックスのための論理演算子
質問
PandasでBooleanインデックスを扱っています。
問題は、なぜこの文なのかです。
a[(a['some_column']==some_number) & (a['some_other_column']==some_other_number)]
は正常に動作するのに対し
a[(a['some_column']==some_number) and (a['some_other_column']==some_other_number)]
はエラーで終了しますか?
例
a = pd.DataFrame({'x':[1,1],'y':[10,20]})
In: a[(a['x']==1)&(a['y']==10)]
Out: x y
0 1 10
In: a[(a['x']==1) and (a['y']==10)]
Out: ValueError: The truth value of an array with more than one element is ambiguous. Use a.any() or a.all()
解決方法は?
と言われたら
(a['x']==1) and (a['y']==10)
あなたは暗黙のうちにPythonに次のように変換するよう求めています。
(a['x']==1)
と
(a['y']==10)
をブール値に変換する。
NumPyの配列(1以上の長さ)やSeriesなどのPandasのオブジェクトは、ブール値を持ちません。
ValueErrorです。配列の真理値があいまいです。a.empty、a.any()、a.all()のいずれかを使用します。
をブール値として使用する場合。それは、それが TrueとFalseのどちらであるべきかが不明確 . Pythonのリストのように、長さが0でなければTrueとするユーザもいるかもしれません。また、次のような場合にのみTrueにすることを望む人もいるかもしれません。 すべて の要素が真である。また、次のような場合に真であってほしいと思うかもしれません。 任意の の要素がTrueになります。
多くの矛盾した期待があるため、NumPyとPandasの設計者は推測を拒否し、代わりにValueErrorを発生させます。
その代わり、明示的に
empty()
,
all()
または
any()
メソッドで、どちらの動作を希望するかを指定します。
しかし、この場合、ブール値の評価は必要ないようです。
要素別
ロジカルアンド それが
&
二項演算子で実行されます。
(a['x']==1) & (a['y']==10)
はブーリアン配列を返します。
ちなみに
alexpmilノート
,
のため、括弧は必須です。
&
は、より高い
演算子の優先順位
よりも
==
.
括弧を除いたもの。
a['x']==1 & a['y']==10
は次のように評価されます。
a['x'] == (1 & a['y']) == 10
という連鎖式比較と同じになります。
(a['x'] == (1 & a['y'])) and ((1 & a['y']) == 10)
. それは、次のような式です。
Series and Series
.
の使用は
and
を2つのSeriesで使用すると、再び同じ
ValueError
と同じです。そのため、括弧は必須です。
関連
-
[解決済み] ValueErrorです。複数の要素を持つ配列の真偽値は曖昧である。a.any()またはa.all()を使用する。
-
[解決済み] for'ループでインデックスにアクセスする?
-
[解決済み] PandasでDataFrameの行を反復処理する方法
-
[解決済み] Pandasのカラム名のリネーム
-
[解決済み] Pandas DataFrameからカラムを削除する
-
[解決済み] Pandasのデータフレームで複数の列を選択する
-
[解決済み] Pandas DataFrameの行数を取得する方法は?
-
[解決済み] ブーリアン値を格納するために使用するMySQLデータ型
-
[解決済み】forループを使った辞書の反復処理
-
[解決済み】Pandas DataFrameのカラムヘッダからリストを取得する。
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
python call matlab メソッドの詳細
-
Pythonショートビデオクローラーチュートリアル
-
Python 入出力と高次代入の基礎知識
-
[解決済み】Pythonスクリプトで「Expected 2D array, got 1D array instead: 」というエラーが発生?
-
[解決済み] builtins.TypeError: strでなければならない、bytesではない
-
[解決済み】 AttributeError("'str' object has no attribute 'read'")
-
[解決済み】ImportError: bs4という名前のモジュールがない(BeautifulSoup)
-
[解決済み】ValueError: pickleプロトコルがサポートされていません。3、python2 pickleはpython3 pickleでダンプしたファイルを読み込むことができない?
-
[解決済み】「OverflowError: Python int too large to convert to C long" on windows but not mac
-
[解決済み】Flaskのテンプレートが見つからない【重複あり