新しいキーを辞書に追加するにはどうすればよいですか?

2009年06月22日に質問されました。  ·  閲覧回数 3.8M回  ·  ソース

lfaraone picture
2009年06月22日

作成後にPython辞書にキーを追加することは可能ですか?

.add()メソッドがないようです。

回答

Paolo Bergantino picture
2009年06月22日
3620
d = {'key': 'value'}
print(d)
# {'key': 'value'}
d['mynewkey'] = 'mynewvalue'
print(d)
# {'key': 'value', 'mynewkey': 'mynewvalue'}

そのキーに値を割り当てることにより、ディクショナリに新しいキーと値のペアを作成します。 キーが存在しない場合は、追加され、その値を指します。 存在する場合は、それが指す現在の値が上書きされます。 —R。ナベガ

user142911 picture
2009年07月22日
1098

複数のキーを同時に追加するには、 dict.update()使用します。

>>> x = {1:2}
>>> print(x)
{1: 2}

>>> d = {3:4, 5:6, 7:8}
>>> x.update(d)
>>> print(x)
{1: 2, 3: 4, 5: 6, 7: 8}

単一のキーを追加する場合、受け入れられた回答の計算オーバーヘッドは少なくなります。

Yugal Jindle picture
2011年12月05日
1019

Python辞書に関する情報を統合したいと思います。

空の辞書を作成する

data = {}
# OR
data = dict()

初期値を使用した辞書の作成

data = {'a': 1, 'b': 2, 'c': 3}
# OR
data = dict(a=1, b=2, c=3)
# OR
data = {k: v for k, v in (('a', 1), ('b',2), ('c',3))}

単一の値の挿入/更新

data['a'] = 1  # Updates if 'a' exists, else adds 'a'
# OR
data.update({'a': 1})
# OR
data.update(dict(a=1))
# OR
data.update(a=1)

複数の値の挿入/更新

data.update({'c':3,'d':4})  # Updates 'c' and adds 'd'

Python 3.9以降:

更新演算子|=が辞書で機能するようになりました。

data |= {'c':3,'d':4}

オリジナルを変更せずにマージされた辞書を作成する

data3 = {}
data3.update(data)  # Modifies data3, not data
data3.update(data2)  # Modifies data3, not data2

Python 3.5以降:

これは、辞書の解凍と呼ばれる新機能を使用します。

data = {**data1, **data2, **data3}

Python 3.9以降:

マージ演算子|が辞書で機能するようになりました。

data = data1 | {'c':3,'d':4}

辞書の項目を削除する

del data[key]  # Removes specific element in a dictionary
data.pop(key)  # Removes the key & returns the value
data.clear()  # Clears entire dictionary

キーがすでに辞書にあるかどうかを確認します

key in data

辞書のペアを反復処理します

for key in data: # Iterates just through the keys, ignoring the values
for key, value in d.items(): # Iterates through the pairs
for key in d.keys(): # Iterates just through key, ignoring the values
for value in d.values(): # Iterates just through value, ignoring the keys

2つのリストから辞書を作成する

data = dict(zip(list_with_keys, list_with_values))
Aaron Hall picture
2014年11月30日
154

「Pythonディクショナリの作成後にキーを追加することは可能ですか?.add()メソッドがないようです。」

はい、それは可能であり、これを実装するメソッドがありますが、直接使用することは望ましくありません。

それを使用する方法と使用しない方法を示すために、dictリテラル{}を使用して空のdictを作成しましょう:

my_dict = {}

ベストプラクティス1:添え字表記

このdictを単一の新しいキーと値で更新するには、アイテムの割り当てを提供する添え字表記(ここのマッピングを参照)を使用できます。

my_dict['new key'] = 'new value'

my_dictは現在:

{'new key': 'new value'}

ベストプラクティス2: updateメソッド-2つの方法

updateメソッドを使用してdict作成している可能性があるため、 dictがすでに作成されており、別の目的で使用されていることを願っています。

my_dict.update({'key 2': 'value 2', 'key 3': 'value 3'})

my_dictは現在:

{'key 2': 'value 2', 'key 3': 'value 3', 'new key': 'new value'}

updateメソッドでこれを行うもう1つの効率的な方法は、キーワード引数を使用することですが、それらは正当なPython単語である必要があるため、スペースや特別な記号を使用したり、名前を数字で始めたりすることはできませんが、多くの人がこれをより読みやすい方法と考えていますdictのキーを作成します。ここでは、余分な不要なdict作成しないようにします。

my_dict.update(foo='bar', foo2='baz')

そしてmy_dictは今:

{'key 2': 'value 2', 'key 3': 'value 3', 'new key': 'new value', 
 'foo': 'bar', 'foo2': 'baz'}

これで、 dictを更新する3つのPythonの方法について説明しました。


魔法の方法、 __setitem__ 、そしてなぜそれを避けるべきなのか

使用してはならないdictを更新する別の方法があります。これは、 __setitem__メソッドを使用します。 これは、 __setitem__メソッドを使用してキーと値のペアをdictに追加する方法の例と、それを使用した場合のパフォーマンスの低下のデモンストレーションです。

>>> d = {}
>>> d.__setitem__('foo', 'bar')
>>> d
{'foo': 'bar'}


>>> def f():
...     d = {}
...     for i in xrange(100):
...         d['foo'] = i
... 
>>> def g():
...     d = {}
...     for i in xrange(100):
...         d.__setitem__('foo', i)
... 
>>> import timeit
>>> number = 100
>>> min(timeit.repeat(f, number=number))
0.0020880699157714844
>>> min(timeit.repeat(g, number=number))
0.005071878433227539

したがって、添え字表記を使用すると、実際には__setitem__を使用するよりもはるかに高速であることがわかります。 Pythonのようなことを行う、つまり、意図された方法で言語を使用することは、通常、より読みやすく、計算効率が高くなります。

Jason Creighton picture
2009年06月22日
101
dictionary[key] = value
Asher picture
2012年04月27日
59

辞書内に辞書を追加したい場合は、この方法で行うことができます。

例:辞書とサブ辞書に新しいエントリを追加します

dictionary = {}
dictionary["new key"] = "some new entry" # add new dictionary entry
dictionary["dictionary_within_a_dictionary"] = {} # this is required by python
dictionary["dictionary_within_a_dictionary"]["sub_dict"] = {"other" : "dictionary"}
print (dictionary)

出力:

{'new key': 'some new entry', 'dictionary_within_a_dictionary': {'sub_dict': {'other': 'dictionarly'}}}

注: Pythonでは、最初にサブを追加する必要があります

dictionary["dictionary_within_a_dictionary"] = {}

エントリを追加する前。

Colonel Panic picture
2013年04月14日
51

従来の構文はd[key] = valueですが、キーボードに角括弧キーがない場合は、次のこともできます。

d.__setitem__(key, value)

実際、 __getitem__ __setitem__メソッドとhttps://python.developpez.com/cours/DiveIntoPython/php/endiveintopython/object_direction_framework/special_class_methods.phpを参照して

kiriloff picture
2013年05月25日
38

次のものを作成できます。

class myDict(dict):

    def __init__(self):
        self = dict()

    def add(self, key, value):
        self[key] = value

## example

myd = myDict()
myd.add('apples',6)
myd.add('bananas',3)
print(myd)

与える:

>>> 
{'apples': 6, 'bananas': 3}
Brent Bradburn picture
2013年08月18日
32

このよくある質問は、辞書abをマージする機能的な方法に対応してい

より簡単な方法のいくつかを次に示します(Python 3でテスト済み)...

c = dict( a, **b ) ## see also https://stackoverflow.com/q/2255878
c = dict( list(a.items()) + list(b.items()) )
c = dict( i for d in [a,b] for i in d.items() )

注:上記の最初の方法は、 bのキーが文字列である場合にのみ機能します。

単一の要素を追加または変更するには、 bディクショナリにはその1つの要素のみが含まれます。

c = dict( a, **{'d':'dog'} ) ## returns a dictionary based on 'a'

これは...と同等です。

def functional_dict_add( dictionary, key, value ):
   temp = dictionary.copy()
   temp[key] = value
   return temp

c = functional_dict_add( a, 'd', 'dog' )
campeterson picture
2018年01月13日
22

不変の世界に住み、オリジナルを変更したくないが、オリジナルに新しいキーを追加した結果である新しいdictを作成したいとします。

Python 3.5以降では、次のことができます。

params = {'a': 1, 'b': 2}
new_params = {**params, **{'c': 3}}

Python2に相当するものは次のとおりです。

params = {'a': 1, 'b': 2}
new_params = dict(params, **{'c': 3})

これらのいずれかの後:

paramsはまだ{'a': 1, 'b': 2}と同じです

そして

new_params{'a': 1, 'b': 2, 'c': 3}と同じです

オリジナルを変更したくない場合があります(オリジナルに追加した結果のみが必要です)。 私はこれが以下のさわやかな代替手段だと思います:

params = {'a': 1, 'b': 2}
new_params = params.copy()
new_params['c'] = 3

または

params = {'a': 1, 'b': 2}
new_params = params.copy()
new_params.update({'c': 3})

参照: https