[解決済み] Pythonでリストをdictのキーとして使えないのはなぜですか?
質問
Pythonのdictのキーとして何が使えるのか、使えないのか、少し混乱しています。
dicked = {}
dicked[None] = 'foo' # None ok
dicked[(1,3)] = 'baz' # tuple ok
import sys
dicked[sys] = 'bar' # wow, even a module is ok !
dicked[(1,[3])] = 'qux' # oops, not allowed
タプルは不変の型ですが、その中にリストを隠すとキーにならないのですね。同じように簡単にモジュールの中にリストを隠すことはできないのでしょうか?
キーが "hashable" でなければならないという漠然とした考えは持っていましたが、技術的な詳細については私自身の無知を認めることにします。 ハッシュをたとえばメモリの場所として、リストをキーとして使用しようとした場合、何がうまくいかないのでしょうか?
どのように解決するのですか?
Pythonのwikiにこのトピックに関する良い記事があります。 なぜリストは辞書のキーになりえないのか . そこで説明されているように
もしあなたがリストをキーとして、ハッシュをそのメモリ位置として使おうとしたら、何が問題なのでしょうか?
それは本当にどの要件も破ることなく行うことができますが、予期しない動作につながります。リストは一般に、たとえば (中略) 等価性をチェックするときに、その値がコンテンツの値から派生したかのように扱われます。多くの人は、当然のことながら、どんなリストでも
[1, 2]
を使用して同じキーを得ることができると期待する人も多いでしょう。しかし、値による検索は、キーとして使用されるリストが変更されるとすぐに壊れ、同一性による検索では、まったく同じリストを保持する必要があります - これは、他の一般的なリスト操作では必要ありません (少なくとも私が思いつく限りではありません)。
モジュールなどの他のオブジェクトや
object
などの他のオブジェクトは、オブジェクトのアイデンティティをより大きく扱います (前回、2 つの異なるモジュールオブジェクトに
sys
と呼ばれる2つの異なるモジュールオブジェクトがあったのはいつだったか)、とにかくそれによって比較されます。したがって、dict キーとして使用される場合、その場合にも ID によって比較されることは、それほど驚くべきことではなく、予想されることでさえあります。
関連
-
[解決済み] 割り当て後にリストが予期せず変更されました。その理由と防止策を教えてください。
-
[解決済み] Python 3で「1000000000000000 in range(1000000000000001)」はなぜ速いのですか?
-
[解決済み] Pythonの辞書からキーを削除するにはどうしたらいいですか?
-
[解決済み] なぜlist.join(string)ではなくstring.join(list)なのでしょうか?
-
[解決済み] なぜList<T>を継承しないのですか?
-
[解決済み] Pythonのdictsで'has_key()'と'in'のどちらを使うべきですか?
-
[解決済み] なぜdict[key]ではなく、dict.get(key)なのか?
-
[解決済み】なぜPythonはこのJSONデータをパースできないのですか?[終了] PythonがこのJSONデータをパースできないのはなぜですか?
-
[解決済み】Pythonで辞書のキーをリストとして返すには?
-
[解決済み] Pythonで0xを使わずにhex()を使うには?
最新
-
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でのAWS Lambdaのインポートモジュールエラー
-
[解決済み] SQLAlchemy: セッションの作成と再利用
-
[解決済み] Pythonです。未束縛のメソッドを束縛する?
-
[解決済み] Pythonのキャッシュライブラリはありますか?
-
[解決済み] PILからopenCVフォーマットへの変換
-
[解決済み] Pythonの要素別タプル演算(sumなど
-
[解決済み] Celeryタスクのユニットテストはどのように行うのですか?
-
[解決済み] if 節の終了方法
-
[解決済み] 単純な文字列からtimedeltaオブジェクトを作成する方法
-
[解決済み] pipの依存性/必要条件をリストアップする方法はありますか?