辞書は、連想マッピングまたは辞書を表す組み込み型です。辞書は、d[k]
を使用したインデックス処理と k in d
を使用したキーメンバーシップ テストをサポートしています。どちらの操作も一定の時間がかかります。フリーズされていない辞書は変更可能で、d[k]
に割り当てたり、特定のメソッドを呼び出したりすることで更新できます。辞書は反復処理可能です。反復処理を行うと、挿入順序のキーのシーケンスが生成されます。反復処理の順序は、既存のキーに関連付けられている値を更新しても影響を受けませんが、キーを削除してから再挿入すると影響を受けます。
d = {0: "x", 2: "z", 1: "y"} [k for k in d] # [0, 2, 1] d.pop(2) d[0], d[2] = "a", "b" 0 in d, "a" in d # (True, False) [(k, v) for k, v in d.items()] # [(0, "a"), (1, "y"), (2, "b")]
辞書を作成するには、次の 4 つの方法があります。
- 辞書式
{k: v, ...}
は、指定されたキー/値エントリを含む新しい辞書を返します。このエントリは、式に現れる順序で挿入されます。2 つのキー式で同じ値が返された場合、評価は失敗します。 - 辞書コンプリヘンション
{k: v for vars in seq}
は、各 Key-Value ペアがループのイテレーション順序で挿入される新しい辞書を生成します。重複は許容されます。特定のキーを最初に挿入することでシーケンス内の位置が決まり、最後の挿入で関連する値が決定されます。{k: v for k, v in (("a", 0), ("b", 1), ("a", 2))} # {"a": 2, "b": 1} {i: 2*i for i in range(3)} # {0: 0, 1: 2, 2: 4}
- 組み込みの dict 関数を呼び出すと、指定されたエントリを含む辞書が返されます。エントリは引数の順序で挿入され、位置引数は名前付き引数の前に挿入されます。コンプリヘンションと同様に、重複するキーは許可されます。
- 結合式
x | y
は、2 つの既存の辞書を組み合わせて新しい辞書を生成します。2 つの辞書にキーk
が共通する場合、右側の辞書のキーの値(つまりy[k]
)が優先されます。ユニオン演算子の|=
バリアントは、辞書をインプレースで変更します。例:d = {"foo": "FOO", "bar": "BAR"} | {"foo": "FOO2", "baz": "BAZ"} # d == {"foo": "FOO2", "bar": "BAR", "baz": "BAZ"} d = {"a": 1, "b": 2} d |= {"b": 3, "c": 4} # d == {"a": 1, "b": 3, "c": 4}
メンバー
クリア
None
dict.clear()
get
unknown dict.get(key, default=None)
key
が辞書に含まれている場合は key
の値を返し、含まれていない場合は default
を返します。default
が指定されていない場合、デフォルトは None
になるため、このメソッドでエラーがスローされることはありません。
パラメータ
パラメータ | 説明 |
---|---|
key
|
必須 検索するキー。 |
default
|
デフォルトは None キーが見つからない場合に使用するデフォルト値(None の代わりに)。 |
アイテム
list dict.items()
{2: "a", 4: "b", 1: "c"}.items() == [(2, "a"), (4, "b"), (1, "c")]
鍵
list dict.keys()
{2: "a", 4: "b", 1: "c"}.keys() == [2, 4, 1]
ポップ
unknown dict.pop(key, default=unbound)
key
を削除し、関連する値を返します。そのキーを持つエントリが見つからない場合は、何も削除せず、指定された default
値を返します。デフォルト値が指定されていない場合は、代わりに失敗します。
パラメータ
パラメータ | 説明 |
---|---|
key
|
必須 キー。 |
default
|
デフォルトは unbound です。キーが存在しない場合のデフォルト値です。 |
popitem
tuple dict.popitem()
(key, value)
ペアを削除して返します。popitem
は、セット アルゴリズムでよく使用されるように、辞書を破壊的に反復処理する場合に便利です。辞書が空の場合、popitem
の呼び出しは失敗します。setdefault
unknown dict.setdefault(key, default=None)
key
がディクショナリ内にある場合は、その値を返します。そうでない場合は、値が default
のキーを挿入し、default
を返します。default
のデフォルトは None
です。
パラメータ
パラメータ | 説明 |
---|---|
key
|
required 鍵。 |
default
|
デフォルトは None です。キーが存在しない場合のデフォルト値です。 |
update
None
dict.update(pairs=[], **kwargs)
pairs
で辞書を更新します。次に、オプションのキーワード引数を指定して、辞書を更新します。位置引数が存在する場合は、辞書、反復可能、または None である必要があります。辞書の場合、Key-Value ペアがこの辞書に挿入されます。イテラブルな場合は、ペアのシーケンス(または長さが 2 の他のイテラブル)を指定する必要があります。各ペアは、挿入される Key-Value ペアとして扱われます。各キーワード引数 name=value
により、この辞書に名前と値のペアが挿入されます。
パラメータ
パラメータ | 説明 |
---|---|
pairs
|
デフォルトは [] です。辞書またはエントリのリストです。エントリは、キーと値の 2 つの要素を持つタプルまたはリストでなければなりません。 |
kwargs
|
必須 追加エントリのディクショナリ。 |
values
list dict.values()
{2: "a", 4: "b", 1: "c"}.values() == ["a", "b", "c"]