创建
方法一:
> 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字典操作详细介绍及字典内建方法分享的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:
python基础练习之几个简单的游戏
Python基础练习之用户登录实现代码分享
Python面向对象编程基础解析(一)
如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]