百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Python入门系列21-Python内置数据结构之字典操作

liuian 2024-11-28 00:43 19 浏览

在Python编程中使用字典必然需要对它进行各种操作,比如取值、删除某个键值对、增加某个键值对、循环、判断键存在等等,而这些操作都可以通过字典自带的方法来轻松的完成。

我们先来查看字典自带有哪些方法。

>>> dir({})
['__class__',
 '__contains__',
 '__delattr__',
 '__delitem__',
 '__dir__',
 '__doc__',
 '__eq__',
 '__format__',
 '__ge__',
 '__getattribute__',
 '__getitem__',
 '__gt__',
 '__hash__',
 '__init__',
 '__init_subclass__',
 '__iter__',
 '__le__',
 '__len__',
 '__lt__',
 '__ne__',
 '__new__',
 '__reduce__',
 '__reduce_ex__',
 '__repr__',
 '__setattr__',
 '__setitem__',
 '__sizeof__',
 '__str__',
 '__subclasshook__',
 'clear',
 'copy',
 'fromkeys',
 'get',
 'items',
 'keys',
 'pop',
 'popitem',
 'setdefault',
 'update',
 'values']

没错,上面我使用两个大括号来声明一个字典,并没有预先去声明一个有键值对的字典。

我们同样忽略以双下划线开头的方法和属性,实际上我们以后几乎都是跟这些方法打交道的。

1、values、keys和items方法

这三个方法很像,values方法会返回字典的所有值,而keys方法会返回字典的所有键,items方法则返回由键和值组成的元组为元素的数据结构,这对我们需要收集字典的值、键或者键值对的时候是很有帮助的。

>>> help({}.values)  # 查看字典values方法的帮助文档
Help on built-in function values:
values(...) method of builtins.dict instance
    D.values() -> an object providing a view on D's values
>>>
>>> help({}.keys) # 查看字典keys方法的帮助文档
Help on built-in function keys:
keys(...) method of builtins.dict instance
    D.keys() -> a set-like object providing a view on D's keys
>>>
>>> help({}.items)
Help on built-in function items:
items(...) method of builtins.dict instance
    D.items() -> a set-like object providing a view on D's items
>>>
>>> url = {
'baidu': 'http://www.baidu.com',
'google': 'http://www.google.com',
'douban': 'http://www.douban.com',
'python': 'http://www.python.org',
}
>>> url
{
'baidu': 'http://www.baidu.com',
'google': 'http://www.google.com',
'douban': 'http://www.douban.com',
'python': 'http://www.python.org',
}
>>> url.values()  #在Python3中,values方法返回一个dict_values,在Python2中会返回一个包含字典值的列表
dict_values(['http://www.baidu.com', 'http://www.google.com', 'http://www.douban.com', 'http://www.python.org'])
>>> list(url.values()) #我们可以利用内置函数list把dict_values转换成列表
['http://www.baidu.com', 'http://www.google.com', 'http://www.douban.com', 'http://www.python.org']
>>>
>>> url.keys()
dict_keys(['baidu', 'google', 'douban', 'python'])
>>> list(url.keys())
['baidu', 'google', 'douban', 'python']
>>>
>>> url.items()
 dict_items([('baidu', 'http://www.baidu.com'), ('google', 'http://www.google.com'), ('douban', 'http://www.douban.com'), ('python', 'http://www.python.org')])
>>> list(url.items())
[('baidu', 'http://www.baidu.com'),
 ('google', 'http://www.google.com'),
 ('douban', 'http://www.douban.com'),
 ('python', 'http://www.python.org')]

2、pop和popitem方法

这两个方法有点似曾相识,没错,在列表操作那一章中也讲到这个方法,方法的作用都差不多,都是把数据结构中的元素给剔除掉,但这两个方法的用法有差别。

>>> help({}.pop)
Help on built-in function pop:
pop(...) method of builtins.dict instance
    D.pop(k[,d]) -> v, remove specified key and return the corresponding value.
    If key is not found, d is returned if given, otherwise KeyError is raised
>>>
>>> help({}.popitem)
Help on built-in function popitem:
popitem(...) method of builtins.dict instance
    D.popitem() -> (k, v), remove and return some (key, value) pair as a
    2-tuple; but raise KeyError if D is empty.

从上面这两个方法的帮助文档可以知道:

pop方法可以接收两个参数,一个必须提供,一个是可选的。必须提供的是字典的键,如果字典存在该键,则会剔除对应的值并返回。如果提供的键在字典中不存在,则会报错,除非同时提供一个可选的参数,则会返回该可选参数。

popitem方法则不接收任何参数,它会随机返回一个由键和值组成的元组,如果空字典使用该方法则会产生一个KeyError错误。

>>> url = {
'baidu': 'http://www.baidu.com',
'google': 'http://www.google.com',
'douban': 'http://www.douban.com',
'python': 'http://www.python.org',
}
>>> url
{
'baidu': 'http://www.baidu.com',
'google': 'http://www.google.com',
'douban': 'http://www.douban.com',
'python': 'http://www.python.org',
}
>>> url.pop('baidu')  # 剔除键'baidu'对应的值
'http://www.baidu.com'
>>> url
{
'google': 'http://www.google.com',
'douban': 'http://www.douban.com',
'python': 'http://www.python.org',
}
>>> url.pop('sina') # 剔除一个不存在的键,并且不提供可选参数
Traceback (most recent call last):
  File "D:\Anaconda3\lib\site-packages\IPython\core\interactiveshell.py", line 2963, in run_code
    exec(code_obj, self.user_global_ns, self.user_ns)
  File "<ipython-input-136-2406404084fd>", line 1, in <module>
    url.pop('sina')
KeyError: 'sina'
>>> url.pop('sina', 'None') # 剔除一个不存在的键,并且提供可选参数
'None'
>>>
>>> url.popitem()
('google', 'http://www.google.com')
>>> {}.popitem()  #空字典执行popitem方法,会产生错误
Traceback (most recent call last):
  File "D:\Anaconda3\lib\site-packages\IPython\core\interactiveshell.py", line 2963, in run_code
    exec(code_obj, self.user_global_ns, self.user_ns)
  File "<ipython-input-138-660ae4b74927>", line 1, in <module>
    {}.popitem()
KeyError: 'popitem(): dictionary is empty'

3、get方法

字典get方法用于获取对应键的值,它中括号法一样,可以获取字典的值,但是它两对待键不存在的情况时表现又不一样。

利用中括号法获取字典某个值的时候,如果字典中不存在该键,则会删除错误。而利用get方法不会报错,这也是推荐大家使用get方法获取值的原因。

get方法可以接收两个参数,一个是必须提供,一个是可选的。键是必须提供的参数,如果字典存在该键,则返回对应的值。如果字典不存在该键,则会返回一个None数据类型,除非提供可选参数来让找不到键的情况下返回可选参数。

>>> help({}.get)
Help on built-in function get:
get(...) method of builtins.dict instance
    D.get(k[,d]) -> D[k] if k in D, else d.  d defaults to None.
>>>
>>>  url = {
'baidu': 'http://www.baidu.com',
'google': 'http://www.google.com',
'douban': 'http://www.douban.com',
'python': 'http://www.python.org',
}
>>> url
{
'baidu': 'http://www.baidu.com',
'google': 'http://www.google.com',
'douban': 'http://www.douban.com',
'python': 'http://www.python.org',
}
>>> url.get('baidu')  # 返回键'baidu'对应的值
'http://www.baidu.com'
>>> print(url.get('zhihu')  #试图获取一个不存在的键,不提供可选参数的情况下返回None
 None
>>> url.get('zhihu', 'http://www.zhihu.com')  # 返回可选参数
 'http://www.zhihu.com'
>>>
>>> url['baidu']
 'http://www.baidu.com'
>>> url['zhihu']  # 没得商量,会产生一个KeyError错误
Traceback (most recent call last):
  File "D:\Anaconda3\lib\site-packages\IPython\core\interactiveshell.py", line 2963, in run_code
    exec(code_obj, self.user_global_ns, self.user_ns)
  File "<ipython-input-161-7d75b393b9db>", line 1, in <module>
    url['zhihu']
KeyError: 'zhihu'

4、update方法

要扩展现有字典经常碰到,也叫作更新字典,该方法可以提供多种类型的参数,比如字典、有特殊要求的列表或者元组。

>>> help({}.update)
Help on built-in function update:
update(...) method of builtins.dict instance
    D.update([E, ]**F) -> None.  Update D from dict/iterable E and F.
    If E is present and has a .keys() method, then does:  for k in E: D[k] = E[k]
    If E is present and lacks a .keys() method, then does:  for k, v in E: D[k] = v
    In either case, this is followed by: for k in F:  D[k] = F[k]
>>>
>>> url = {
'baidu': 'http://www.baidu.com',
'google': 'http://www.google.com',
'douban': 'http://www.douban.com',
'python': 'http://www.python.org',
}
>>> url
{
'baidu': 'http://www.baidu.com',
'google': 'http://www.google.com',
'douban': 'http://www.douban.com',
'python': 'http://www.python.org',
}
>>> new_dict = {'zhihu': 'http://www.zhihu.com'} #定义一个新的字典
>>> url.update(new_dict)
>>> url
{'baidu': 'http://www.baidu.com',
 'google': 'http://www.google.com',
 'douban': 'http://www.douban.com',
 'python': 'http://www.python.org',
 'zhihu': 'http://www.zhihu.com'}
>>>
>>> url.update([('name', 'python'),( 'age',28)])
{'baidu': 'http://www.baidu.com',
 'google': 'http://www.google.com',
 'douban': 'http://www.douban.com',
 'python': 'http://www.python.org',
 'zhihu': 'http://www.zhihu.com',
 'name': 'python',
 'age': 28}

5、setdefaut方法

setdefautl方法可以说是get方法的升级版,该方法同样也可以接收两个参数,一个必须提供,就是字典的键。另一个是可选的,在有些时候这个可选参数作用很大。

1、如果两个参数同时提供,当字典中存在该键时,则返回键对应的值。如果字典中不存在该键,则该字典会利用键参数为新键,可选参数为值作为新元素添加的字典中,并且返回可选参数。

2、如果只提供键参数,如果字典中存在该键,则返回对应值。如果不存在,则返回None

>>> help({}.setdefault)
Help on method_descriptor:
setdefault(...)
    D.setdefault(k[,d]) -> D.get(k,d), also set D[k]=d if k not in D
>>> d = {}
>>> d.setdefault('name') #空字典不存在该键,返回None

>>> d.setdefault('name', 'Python')
'

6、删除字典键值对及字典

除了可以使用pop和popitem方法来删除字典键值对外,我们可以使用del来删除。

>>>  url = {
'baidu': 'http://www.baidu.com',
'google': 'http://www.google.com',
'douban': 'http://www.douban.com',
'python': 'http://www.python.org',
}
>>> url
{
'baidu': 'http://www.baidu.com',
'google': 'http://www.google.com',
'douban': 'http://www.douban.com',
'python': 'http://www.python.org',
}
>>> del url['baidu'] #删除某个键值对
>>> url
{'google': 'http://www.google.com',
 'douban': 'http://www.douban.com',
 'python': 'http://www.python.org'}
>>> del url #删除整个字典
>>> url # url已不存在,会报错
Traceback (most recent call last):
  File "D:\Anaconda3\lib\site-packages\IPython\core\interactiveshell.py", line 2963, in run_code
    exec(code_obj, self.user_global_ns, self.user_ns)
  File "<ipython-input-196-5446fb31b66c>", line 1, in <module>
    url
NameError: name 'url' is not defined

相关推荐

Docker 47 个常见故障的原因和解决方法

【作者】曹如熙,具有超过十年的互联网运维及五年以上团队管理经验,多年容器云的运维,尤其在Docker和kubernetes领域非常精通。Docker是一种相对使用较简单的容器,我们可以通过以下几种方式...

电脑30个快问快答,解决常见电脑问题

1.强行关机/停电对电脑有影响吗?答:可能损坏硬盘(机械硬盘风险高)、未保存数据丢失,偶尔一次影响小,但频繁操作会缩短硬件寿命。2.C盘满影响速度吗?答:会!系统运行需C盘空间缓存临时数据,空间不...

使用Tcpdump包抓取分析数据包的详细用法

TcpDump可以将网络中传送的数据包的“头”完全截获下来提供分析。它支持针对网络层、协议、主机、网络或端口的过滤,并提供and、or、not等逻辑语句来帮助你去掉无用的信息。tcpdump就是一种...

电脑启动不了(BootDevice Not Found Hard Disk-3F0)解决方案

HP品牌机,开机启动不了,黑屏,开机取下主板电池恢复BIOS后,开机显示找不到启动盘。一、按F2键进入BIOS,出现硬盘内存检测界面的话,直接退出。就会出现这个界面,光标键向下,选择BIOSSetu...

电脑开机黑屏别慌!快码住!起底维修老师傅不能说的秘密

按下开机键却只收获黑屏大礼包?那些神秘的英文提示、刺耳的蜂鸣声,其实是电脑在给你发送求救信号!从按下电源到进入桌面的12秒里,你的电脑经历了史诗级的硬件自检与系统加载,今天我们就破译这段“摩斯电码”。...

电脑启动故障为何总要先看BIOS?新手必读的关键知识解析

最近在帮朋友们解答电脑无法正常开机的问题时,发现大家经常收到一句高频建议:“先检查BIOS”。对不少普通用户而言,BIOS依然是个神秘的存在。那么,BIOS到底是什么?电脑出现哪些故障会与它相关呢?本...

Windows 11 KB5053598更新:安全补丁还是系统噩梦?

2025年3月11日,微软发布了Windows1124H2的强制性更新KB5053598,作为“周二补丁日”(PatchTuesday)的一部分。然而,这款本应提升系统安全性的更新却引发了广泛的...

飞牛OS入门安装遇到问题,如何解决?

之前小编尝试了用旧电脑装飞牛OS安装之前特意查了一些硬件要求飞牛OS目前支持主流的x86架构硬件主机需能连网线飞牛OS暂时不支持只有无线网卡的安装貌似很多小伙伴在一开始安装就卡住了那今天咱们汇总分...

几种常见的电脑开机黑屏显示白色英文字母解决方法

当电脑开机出现黑屏并显示白色英文字母时,通常表示系统启动过程中遇到了错误。以下是几种常见原因及对应的解决方法,按照排查顺序整理:一、检查外接设备与硬件连接可能原因:外接U盘、移动硬盘等未拔出,或内部硬...

电脑启动出现问题,为什么都要先检查BIOS?

【ZOL中关村在线原创技巧应用】最近在回答问题的时候,总会发现很多朋友都在问“电脑无法正常开机怎么办?”这样类似的问题,而许多DIY大佬的回复总会出现一条高频建议“先检查BIOS”。但对于许多普通用户...

教你怎么用JavaScript检测当前浏览器是无头浏览器

什么是无头浏览器(headlessbrowser)?无头浏览器是指可以在图形界面情况下运行的浏览器。我可以通过编程来控制无头浏览器自动执行各种任务,比如做测试,给网页截屏等。为什么叫“无头”浏览器?...

12个高效的Python爬虫框架,你用过几个?

实现爬虫技术的编程环境有很多种,Java、Python、C++等都可以用来爬虫。但很多人选择Python来写爬虫,为什么呢?因为Python确实很适合做爬虫,丰富的第三方库十分强大,简单几行代码便可实...

运维的报表之路,用 node.js 轻松发送 grafana 报表

在运维过程中,无论是监控还是报表,都会有一些通过邮件发送图表的需求,由于开源的zabbix,grafana和kibana等并不完全具有“想发送哪儿就发送哪儿”的图片生成功能,在grafana...

C#基于浏览器内核的高级爬虫(c#爬取网页内容)

基于C#.NET+PhantomJS+Sellenium的高级网络爬虫程序。可执行Javascript代码、触发各类事件、操纵页面Dom结构、甚至可以移除不喜欢的CSS样式。很多网站都用Ajax动态加...

如何优化一个秒杀项目?(秒杀实现思路)

问题1:使用jmeter性能压测,定位瓶颈代码步骤流程:线程组--->Http请求--->查看结果树--->聚合报告tips:host的文件--->优先调用映射,减少DNS的时...