python字典中get()函数的用法个人小结

caocao2年前教程381

在线wifi跑包 金刚包跑包 cap跑包 hccapx ewsa在线 就来 曹操wifi

各位好 又见面了 我是曹操 今天给大家带来一篇新的教程

希望各位细心学习 低调用网

print(dict[key])

以下内容均为个人笔记,仅供学习参考使用,内容均为自己实践经验总结,且作者编写此文章时只关注作用而非实现原理,且因个人水平有限,文章中部分错误,可移至评论区观看其他大佬的解答 注:编程语言为Python3

  1. get()函数利用键来获取值

之前在学习python的时候,在获取值得时候常用的方法就是直接

print(dict.get(key))
cdlinux添加字典详细教程学习
ls=['aa','b','c','ddd','aa']

但这种方法中当字典中不存在该键时会返回KeyError类型错误,此时就可以用get()函数还利用键获取值 利用get()函数操作时当字典中不存在输入的键时会返回一个None,这样程序运行时就不会出异常

  1. 利用字典统计列表中元素出现次数

比如现在有这么一个列表,让你统计列表中部分元素出现的次数

cou={} #创建一个空字典
for i in ls:
    cou[i]=cou.get(i,0)+1     #之后称其为get的赋值语句,目的是新建字典键值对
    
    '''
    赋值语句代码效果等同于
    cou[i]=0
    cou[i}=cou[i]+1
    '''
print(cou)
cdlinux添加字典详细教程学习
{'aa': 2, 'b': 1, 'c': 1, 'ddd': 1}
cou.get('b',10)   #之后称为拟定初值语句

统计列表中每个元素出现次数:

输出结果:

get()函数在这里有两个参数,第一个是确定要分配值的键,第二个是拟定给键分配一个初值,但实际要给键赋值仍需要get赋值语句(为什么这么说下面有介绍) 比如说我现在添加这个语句到代码中

ls=['aa','b','c','ddd','aa']
cou={} #创建一个空字典
for i in ls:
	cou[i]=cou.get(i,0)+1  #功能逻辑看下方阐述
cou['aa']=cou.get('aa',10)  #功能同前一条代码执行到第二次时的
print(cou)

拟定初值语句本身对结果是没有影响的,因为并没有实际的对键进行赋值语句操作(个人感觉拟定初值语句是因为没有在字典中找到要赋值的键,因为根本没有创建要赋值的键,因此赋值失败,即相当于一个没有返回值的函数,就算给这个函数赋参数了也没有任何返回结果) 注:get()函数在作为键赋值语句(非拟定赋值语句,区别看上代码框内注释)时只有第一次是有效的,(比如get()函数在第一次对’aa’这个键使用get赋值语句后下次再使用get赋值语句时键的值仍为第一次赋值运算后的结果),以下为测试代码:

cdlinux添加字典详细教程学习

这里着重讲一下第4行代码:cou[i]=cou.get(i,0)+1 第行代码从逻辑上讲执行了两次,而这两次里get语句每次执行时的功能是不一样的: 第一次:cou[i]=cou.get(i,0)+1(i=‘aa’) 此时get语句的功能为赋初值,即把键’aa’的初值置为0然后加1 第二次:cou[i]=cou.get(i,0)+1(i=‘aa’) 因get语句已经作为赋值语句出现过一次了,因此此时再执行这条语句时,赋值功能已经无效了,也就是get语句里第二个参数对’aa’这个键已经无效了,此时get语句的功能为文章内的第一大部分所介绍的功能,所以这条语句此时可等价为 cou[i]=cou.get(i)+1cou[i]=cou[i]+1 输出结果和之前的代码结果相同:

{'aa': 2, 'b': 1, 'c': 1, 'ddd': 1}
cou['e']=cou.get(e,10) 
输出结果:
```python
{'aa': 10, 'b': 1, 'c': 1, 'ddd': 1,'e':10}
cou['aa']=10  #这种赋值语句带有强制性
print(cou)
{'aa': 10, 'b': 1, 'c': 1, 'ddd': 1}

相关文章

无线网络密码破解WPA/WPA2教程(图文介绍包教包会)

无线网络密码破解WPA/WPA2教程(图文介绍包教包会)

wpa2无线网络密码破解详细的方法介绍 本教程旨在探索无线路由安全漏洞,但禁止非法用途,违者必究(与我无关)。在开始破解WPA/WPA2之前,我们应该先了解一些基础知识。首先,我们要了解一种数学运算,...

Kali Linux无线渗透测试入门指南 第一章 配置无线环境

极客的无线渗透测试环境搭建指南 硬件要求 为了建立无线环境,我们需要以下硬件配置: 两台带有内置 WiFi 网卡的笔记本电脑:一台作为受害者,一台作为渗透测试者。推荐笔记本电脑至少具备 3GB RA...

流程全曝光:黑客如何黑掉你的手机?

流程全曝光:黑客如何黑掉你的手机?

极客式复述: 智能手机的安全性与黑客攻击 智能手机已经成为人们生活中不可或缺的一部分。除了打电话,智能手机还可以用于上网、收发邮件、聊天、社交、拍照和付款等各种功能,简直是一条龙服务。统计数据显示,全...

aircrack & hashcat 非字典高速破解目标无线密码(技术分享)

aircrack & hashcat 非字典高速破解目标无线密码(技术分享)

在线wifi跑包 金刚包跑包 cap跑包 hccapx ewsa在线 就来 曹操wifi 各位好 又见面了 我是曹操 今天给大家带来一篇新的教程 希望各位细心学习 低调用网 0x01 挂载好外置无线...