Pergunta

É possível adicionar uma chave para um dicionário Python depois de ter sido criado? Não parece ter um método .add().

Foi útil?

Solução

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

Outras dicas

Para adicionar simultaneamente as teclas:

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

Para adicionar uma única tecla, a resposta aceita tem sobrecarga menos computacional.

Eu sinto como se consolidando informações sobre dicionários Python:

Criando um vazio dicionário

data = {}
# OR
data = dict()

Criando um dicionário com os valores iniciais

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

Inserir / Atualizar um único valor

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)

Inserir / Atualizar vários valores

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

Criando um dicionário mesclado, sem modificar originais

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

excluir itens no dicionário

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

Verificar se uma chave já está no dicionário

key in data

Iterate através de pares em um dicionário

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

Criar um dicionário de 2 listas

data = dict(zip(list_with_keys, list_with_values))

Sinta-se livre para adicionar mais!

"É possível adicionar uma chave para um dicionário Python depois de ter sido criado? Não parece ter um método .add ()."

Sim, é possível, e ele tem um método que implementa isso, mas você não quiser usá-lo diretamente.

Para demonstrar como e como não usá-lo, vamos criar um dict vazio com o literal dict, {}:

my_dict = {}

Best Practice 1: Subscrito notação

Para atualizar esse dict com uma única nova chave e valor, você pode usar a notação subscrito (ver mapeamentos aqui) que prevê a atribuição de artigo:

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

my_dict agora é:

{'new key': 'new value'}

Best Practice 2: O método update - 2 maneiras

Nós também pode atualizar o dict com vários valores de forma eficiente, bem usando o método update . Podemos ser desnecessariamente a criação de um dict extra aqui, então esperamos que a nossa dict já foi criado e veio ou foi usado para outra finalidade:

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

my_dict agora é:

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

Outra maneira eficiente de fazer isso com o método de atualização é com argumentos de palavra-chave, mas desde que eles têm que ser palavras python legítimos, você não pode ter espaços ou símbolos especiais nem iniciar o nome com um número, mas muitos consideram este um forma mais legível para criar chaves de um dicionário, e aqui nós certamente evitar a criação de um dict desnecessária extra:

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

e my_dict agora é:

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

Então, agora nós cobrimos três maneiras Pythonic de atualizar um dict.


método mágico, __setitem__, e por isso deve ser evitado

Há uma outra maneira de atualizar um dict que você não deve usar, que utiliza o método __setitem__. Aqui está um exemplo de como se pode usar o método __setitem__ para adicionar um par chave-valor a uma dict, e uma demonstração do mau desempenho de usá-lo:

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

Assim, vemos que o uso da notação subscrita é realmente muito mais rápido do que usar __setitem__. Fazer a coisa Pythonic, isto é, usando a linguagem na forma como foi concebido para ser usado, geralmente é tanto mais legível e computacionalmente eficiente.

dictionary[key] = value

Se você quiser adicionar um dicionário dentro de um dicionário que você pode fazê-lo desta forma.

Exemplo: Adicione uma nova entrada ao dicionário & sub dicionário

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)

Output:

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

NOTA: Python requer que você primeiro adicionar um sub

dictionary["dictionary_within_a_dictionary"] = {}

antes de adicionar entradas.

A sintaxe ortodoxa é d[key] = value, mas se o seu teclado está faltando as chaves colchete você poderia fazer:

d.__setitem__(key, value)

Na verdade, definir métodos __getitem__ e __setitem__ é como você pode fazer o seu próprio suporte de classe a sintaxe colchete. Consulte https://python.developpez.com/cours/DiveIntoPython /php/endiveintopython/object_oriented_framework/special_class_methods.php

Você pode criar um

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}

Esta questão populares endereços funcional métodos de fusão dicionários a e b.

Aqui estão alguns dos métodos mais simples (testado em 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() )

Nota:. O primeiro método acima só funciona se as chaves na b são cadeias

Para adicionar ou modificar um único elemento , o dicionário b conteria apenas que um elemento ...

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

Isto é equivalente a ...

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

c = functional_dict_add( a, 'd', 'dog' )

Vamos fingir que você quer viver no mundo imutável e não quer modificar o original, mas deseja criar um novo dict que é o resultado da adição de uma nova chave para o original.

Em Python 3.5+ você pode fazer:

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

O Python 2 equivalente é:

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

Depois de um desses:

params ainda é igual a {'a': 1, 'b': 2}

e

new_params é igual a {'a': 1, 'b': 2, 'c': 3}

Haverá momentos em que você não deseja modificar o original (só deseja o resultado da adição ao original). Acho isso uma alternativa refrescante para o seguinte:

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

ou

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

Referência: https://stackoverflow.com/a/2255892/514866

Assim, muitas respostas e ainda toda a gente se esqueceu do nome estranho, estranhamente comportado, e ainda assim acessível dict.setdefault()

Este

value = my_dict.setdefault(key, default)

basicamente apenas faz isso:

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

por exemplo.

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

Se você não está juntando dois dicionários, mas a adição de novos pares chave-valor a um dicionário, em seguida, usando a notação subscrita parece ser o melhor caminho.

import timeit

timeit.timeit('dictionary = {"karga": 1, "darga": 2}; dictionary.update({"aaa": 123123, "asd": 233})')
>> 0.49582505226135254

timeit.timeit('dictionary = {"karga": 1, "darga": 2}; dictionary["aaa"] = 123123; dictionary["asd"] = 233;')
>> 0.20782899856567383

No entanto, se você gostaria de adicionar, por exemplo, milhares de novos pares chave-valor, você deve considerar o uso o método update().

primeiro a verificar se a chave já existe

a={1:2,3:4}
a.get(1)
2
a.get(5)
None

então você pode adicionar a nova chave e valor

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top