python字典操作

2019-03-19 00:52|来源: 网络

python里的字典就像java里的HashMap,以键值对的方式存在并操作,其特点如下

  • 通过键来存取,而非偏移量;

  • 键值对是无序的;

  • 键和值可以是任意对象;

  • 长度可变,任意嵌套;

  • 在字典里,不能再有序列操作,虽然字典在某些方面与列表类似,但不要把列表套在字典上

1) 基本操作

>>> table = {'abc':1, 'def':2, 'ghi':3}   
>>> table['abc']   
1  
>>> len(table)   
3  
>>> table.keys()   
['abc', 'ghi', 'def']   
>>> table.values()   
[1, 3, 2]   
>>> table.has_key('def')   
True 
>>> table.items()   
[('abc', 1), ('ghi', 3), ('def', 2)]


2) 修改,删除,添加

>>> table = {'abc':1, 'def':2, 'ghi':3}   
>>> table['ghi'] = ('g', 'h', 'i')   
>>> table   
{'abc': 1, 'ghi': ('g', 'h', 'i'), 'def': 2}   
>>> del table['abc']   
>>> table   
{'ghi': ('g', 'h', 'i'), 'def': 2}   
>>> table['xyz'] = ['x', 'y', 'z']   
>>> table   
{'xyz': ['x', 'y', 'z'], 'ghi': ('g', 'h', 'i'), 'def': 2}

在这里需要来一句,对于字典的扩充,只需定义一个新的键值对即可,而对于列表,就只能用append方法或分片赋值。


3)对字典的遍历

>>> table = {'abc':1, 'def':2, 'ghi':3}   
>>> for key in table.keys():   
    print key, '\t', table[key]   
        
abc     1  
ghi     3  
def     2

创建

方法一:

>>> dict1 = {}
>>> dict2 = {'name': 'earth', 'port': 80}
>>> dict1, dict2
({}, {'port': 80, 'name': 'earth'})

方法二:从Python 2.2 版本起,可以使用一个工厂方法,传入一个元素是列表的元组作为参数

>>> fdict = dict((['x', 1], ['y', 2]))
>>> fdict
{'y': 2, 'x': 1}

方法三:

从Python 2.3 版本起, 可以用一个很方便的内建方法fromkeys() 来创建一个"默认"字典, 字典中元素具有相同的值 (如果没有给出, 默认为None,这个有点像我框架的oneObject方法):

>>> ddict = {}.fromkeys(('x', 'y'), -1) 
>>> ddict
{'y': -1, 'x': -1}
>>>
>>> edict = {}.fromkeys(('foo', 'bar'))
>>> edict
{'foo': None, 'bar': None}

访问字典中的值

想遍历一个字典(一般用键), 你只需要循环查看它的键, 像这样:

>>> dict2 = {'name': 'earth', 'port': 80}
>>>
>>>> for key in dict2.keys():
... print 'key=%s, value=%s' % (key, dict2[key])
...
key=name, value=earth
key=port, value=80

从Python 2.2 开始,可以直接在 for 循环里遍历字典。

>>> dict2 = {'name': 'earth', 'port': 80}
>>>
>>>> for key in dict2:
... print 'key=%s, value=%s' % (key, dict2[key])
...
key=name, value=earth
key=port, value=80

想判定其是否存在某个键值对,可以使用has_key()或 in 、 not in 操作符

>>> 'server' in dict2 # 或 dict2.has_key('server')
False
>>> 'name' in dict # 或 dict2.has_key('name')
True
>>> dict2['name']
'earth'

一个字典中混用数字和字符串的例子:

>>> dict3 = {}
>>> dict3[1] = 'abc'
>>> dict3['1'] = 3.14159
>>> dict3[3.2] = 'xyz'
>>> dict3
{3.2: 'xyz', 1: 'abc', '1': 3.14159}

更新字典

采取覆盖更新

上例中 dict2['name']='earth';

更新 dict2['name']='abc';

删除字典元素和字典

del dict2['name'] # 删除键为“name”的条目

dict2.clear() # 删除dict2 中所有的条目

del dict2 # 删除整个dict2 字典

dict2.pop('name') # 删除并返回键为“name”的条目

dict2 = {'name': 'earth', 'port': 80}
>>> dict2.keys()
['port', 'name']
>>>
>>> dict2.values()
[80, 'earth']
>>>
>>> dict2.items()
[('port', 80), ('name', 'earth')]
>>>
>>> for eachKey in dict2.keys():
... print 'dict2 key', eachKey, 'has value', dict2[eachKey]
...
dict2 key port has value 80
dict2 key name has value earth

update()方法可以用来将一个字典的内容添加到另外一个字典中

dict3 = {'server': 'http', 'port': 80, 'host': 'venus'}
>>> dict3.clear()
>>> dict3
{}

映射类型相关的函数

>>> dict(x=1, y=2)
{'y': 2, 'x': 1}
>>> dict8 = dict(x=1, y=2)
>>> dict8
{'y': 2, 'x': 1}
>>> dict9 = dict(**dict8)
>>> dict9
{'y': 2, 'x': 1}
 
dict9 = dict8.copy()

字典内建方法

方法名字操作
dict.clear()删除字典中所有元素
dict.copy()返回字典(浅复制)的一个副本
dict.fromkeysc(seq,val=None)创建并返回一个新字典,以seq 中的元素做该字典的键,val 做该字典中所有键对应的初始值(如果不提供此值,则默认为None)
dict.get(key,default=None)对字典dict 中的键key,返回它对应的值value,如果字典中不存在此键,则返回default 的值(注意,参数default 的默认值为None)
dict.has_key(key)如果键(key)在字典中存在,返回True,否则返回False. 在Python2.2版本引入in 和not in 后,此方法几乎已废弃不用了,但仍提供一个 可工作的接口。
dict.items()返回一个包含字典中(键, 值)对元组的列表
dict.keys()返回一个包含字典中键的列表
dict.values()返回一个包含字典中所有值的列表
dict.iter()方法iteritems(), iterkeys(), itervalues()与它们对应的非迭代方法一样,不同的是它们返回一个迭代子,而不是一个列表。
dict.pop(key[, default])和方法get()相似,如果字典中key 键存在,删除并返回dict[key],如果key 键不存在,且没有给出default 的值,引发KeyError 异常。
dict.setdefault(key,default=None)和方法set()相似,如果字典中不存在key 键,由dict[key]=default 为它赋值。
dict.setdefault(key,default=None)和方法set()相似,如果字典中不存在key 键,由dict[key]=default 为它赋值。


本文链接:python字典操作,转自网络

相关问答

更多
  • http://www.runoob.com/python/python-dictionary.html 上面有详细的例子
  • 递归。 用这个函数把dict里面的所有value用递归的方法提取到一个空list里面 def dict2flatlist(d,l): print(d) for x in d.keys(): if type(d[x]) == dict: dict2flatlist(d[x],l) else: l.append(d[x]) d = {1:"a",2:"b",3:{4:"c",5:"d",6:{7:"e"}},8:"f"} l = [] dict2flatlist(d,l) print(l)希望对你有帮助
  • python字典赋值[2022-06-21]

    简单举个例子: dic = {'key':1,'key2':'str'} 赋新值例子: dic['key3'] = 0 dic['key4'] = 'sss' 替换现在值: dic['key'] = 2
  • 队字典的写入操作类似json格式的数据增加key一样 比如字典a = {} a[key] = value 这就增加了key,对应的值是value
  • 应为在python中dict是可变对象。用dic1赋值给dic3后,并没有创建一个新的对象,dic3和dic1指向同一个对象。通过dic3改变其内容,就如同通过dic1改变对象内容一样。 具体的内容你可以看看深拷贝和浅拷贝 import copy def com_weight(dic1,dic2): dic3 = copy.deepcopy(dic1) #深拷贝,,,, for i in dic1.keys(): for j in dic1[i].keys(): dic3[i][j]=dic1[i][j]- ...
  • 使用set & other_set运算符或set.intersection和itertools.combinations : >>> import itertools >>> >>> d = {'A':['a', 'b'], 'B':['c', 'b', 'a'], 'C':['d', 'c'], } >>> for a, b in itertools.combinations(d, 2): ... common = set(d[a]) & set(d[b]) ... print('{}&{ ...
  • 像这样的东西? current_dict = myDict mystring = "classes.students.grades" myPath = mystring.split(".") for part in myPath: current_dict = current_dict[part] 但是我认为如果你只是告诉我们你想要的是什么,可能会有更简单的方法。 Something like this? current_dict = myDict mystring = "classes.stud ...
  • 这符合您的代码示例: >>> lst = [1,2,3] >>> newlst = [dict(number=n) for n in lst] >>> newlst [{'number': 1}, {'number': 2}, {'number': 3}] >>> 然而,你所说的有点不同 - 你想要它们都在同一个字典中,或者每个都在自己的字典中? 上面的代码段为您提供后者。 This matches your code samples: >>> lst = [1,2,3] >>> newlst = [d ...
  • {k:d1.get(k, k in d1 or d2[k]) for k in set(d1) | set(d2)} : {k:d1.get(k, k in d1 or d2[k]) for k in set(d1) | set(d2)} {k:d1.get(k, k in d1 or d2[k]) for k in set(d1) | set(d2)}和| 可以被任何其他设定的操作员替换。 基于@ torek的评论,另一个可能更容易记住的配方(尽管是完全一般的)是: {k:d1.get(k,d2.get( ...
  • max()函数迭代其第一个参数,将键函数应用于每个项目并选择具有最大键的项目。 迭代字典与迭代字符串相同。 执行时 max(tall_buildings, key=tall_buildings.get) 我们将首先遍历tall_buildings所有键。 对于每个键k ,将评估关键函数tall_buildings.get(k) ,其返回由k表示的建筑物的高度。 然后选择并返回具有最大高度的k 。 The max() function iterates over its first argument, ap ...