Добавить новые ключи в словарь?

можно ли добавить ключ в словарь Python после его создания? Кажется, у него нет .add() метод.

19 ответов


>>> d = {'key':'value'}
>>> print(d)
{'key': 'value'}
>>> d['mynewkey'] = 'mynewvalue'
>>> print(d)
{'mynewkey': 'mynewvalue', 'key': 'value'}

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

>>> x.update({3:4})
>>> print x
{1: 2, 3: 4}

мне хочется консолидировать информацию о словарях 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'

создание объединенного словаря без изменения оригиналов

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

удаление элементов в словарь

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

проверьте, если a ключ уже в словаре

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))

не стесняйтесь добавлять больше!


Да, это довольно легко. Просто сделайте следующее:

dict["key"] = "value"

" можно ли добавить ключ в словарь Python после его создания? Кажется, у него нет .метод add."

Да, это возможно, и это есть метод, который реализует это, но вы не хотите использовать его напрямую.

чтобы продемонстрировать, как и как не использовать его, давайте создадим пустой дикт с литералом дикт,{}:

my_dict = {}

Лучшая практика 1: Обозначение индекса

обновить это дикт с одним новым ключом и значением, вы можете использовать обозначение индекса (см. сопоставления здесь) это предусматривает назначение элемента:

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

my_dict сейчас:

{'new key': 'new value'}

Лучшая Практика 2:update Способ - 2 способ

мы также можем обновить dict с несколькими значениями эффективно, а также с помощью the 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-с аргументами ключевых слов, но поскольку они должны быть законными словами 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.


магический метод, __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__. Использование языка в том виде, в каком он был предназначен для использования, обычно является более читаемым и вычислительно эффективным.


dictionary[key] = value

Если вы хотите добавить словарь в словарь, вы можете сделать это таким образом.

пример: добавьте новую запись в словарь & sub dictionary

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 требует, чтобы вы сначала добавили sub

dictionary["dictionary_within_a_dictionary"] = {}

перед добавлением записи.


православные синтаксис d[key] = value, но если на клавиатуре отсутствуют квадратные скобки, вы можете сделать:

d.__setitem__(key, value)

на самом деле, определение __getitem__ и __setitem__ методы-это то, как вы можете сделать свой собственный класс поддерживающим синтаксис квадратной скобки. Смотри http://www.diveintopython.net/object_oriented_framework/special_class_methods.html


вы можете создать один

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}

Этот популярный вопрос адреса функциональное методы объединения словарей a и b.

вот некоторые из более простых методов (проверено в 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 словарь будет содержать только один элемент...

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' )

data = {}
data['a'] = 'A'
data['b'] = 'B'

for key, value in data.iteritems():
    print "%s-%s" % (key, value)

результаты

a-A
b-B

это именно то, как я бы это сделал: # исправлены данные с помощью sapce

data = {}
data['f'] = 'F'
data['c'] = 'C'

for key, value in data.iteritems():
    print "%s-%s" % (key, value)

это работает для меня. Наслаждайтесь!


давайте притворимся, что вы хотите жить в неизменяемом мире и не хотите изменять оригинал, но хотите создать новый dict это результат добавления нового ключа к оригиналу.

в Python 3.5+ вы можете сделать:

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

эквивалент Python 2:

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://stackoverflow.com/a/2255892/514866


мы можем добавить новые ключи в словаре таким образом:

Имя Словаря[New_Key_Name] = New_Key_Value

вот пример:

# This is my dictionary
my_dict = {'Key1': 'Value1', 'Key2': 'Value2'}
# Now add new key in my dictionary
my_dict['key3'] = 'Value3'
# Print updated dictionary
print my_dict

выход:

{'key3': 'Value3', 'Key2': 'Value2', 'Key1': 'Value1'}

так много ответов, и все еще все забыли о странно названных, странно себя вели, и все еще удобно dict.setdefault()

этой

value = my_dict.setdefault(key, default)

в основном просто делает это:

try:
    value = my_dict[key]
except KeyError: # key not found
    value = my_dict[key] = default

например

>>> mydict = {'a':1, 'b':2, 'c':3}
>>> mydict.setdefault('d', 4)
4 # returns new value at mydict['d']
>>> print(mydict)
{'a':1, 'b':2, 'c':3, 'd':4} # a new key/value pair was indeed added
# but see what happens when trying it on an existing key...
>>> mydict.setdefault('a', 111)
1 # old value was returned
>>> print(mydict)
{'a':1, 'b':2, 'c':3, 'd':4} # existing key was ignored

Он имеет метод обновления, который вы можете использовать следующим образом:

dict.update({"key" : "value"})


в основном два простых способа с помощью которых можно добавить новый ключ в dict

dict_input = {'one': 1, 'two': 2, 'three': 3}

#1. Set a new value
dict_input['four'] = 4

#2. or use the update() function
dict_input.update({'five': 5})

Я бы сделал это так. Следите за directory[name]=number часть.

n = int(raw_input())
directory={}
entry={}
# store the values as if they appear in the stdin
for i in xrange(n):
    name, number = raw_input().split()
    directory[name]=number

#  query the values    
while (True):
    queryname = (str) (raw_input())
    try:
        strdisp = queryname + "=" + directory[queryname]
        print strdisp
    except:
      print 'Not found'

используйте оператор присвоения индекса:

d['x'] = "value"

не забывайте, что ключ, что Python может ничем hashable, что означает bool, int, string даже кортеж или любые объекты hashable.