【python教程入门学习】基础篇: 4. Python按图索骥的字典dict

2024-03-02 18:58

本文主要是介绍【python教程入门学习】基础篇: 4. Python按图索骥的字典dict,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

dict和list就是Python倚天剑和屠龙刀,dict是一个key-value容器结构,通过一个键去查到对应的元素,就像知道某个人的身份证号,可以通过容器查到该人的姓名。如果不用对象的情况下,dict可以完成大部分简单的工作,所以dict在Python里面几乎是必定用到的一个容器。

dict是用花括号包围,里面是一对对键值对,用逗号隔开,一般键可以用字符串或者整型,而值可以是任意对象。

  1. 基本用法
    1.1 初始化

a = dict()

推荐下面的初始化方式

a = {}

关键词传参方式可以很好地初始化dict

a = dict(key=“value”)
{“key”:“value”}

1.2 插入元素

a = {}
a[“name”] = “Tom”
a[1000] = 3
print(a)
{“name”:“Tom”, 1000:3}

1.3 访问元素

print(a[“name”])
“Tome”
print(a.get(“name”, “default_name”))
“Tome”

如果用中括号访问不存在的键值对,会报错KeyError

print(a[“c”])

特别推荐使用get(key, default)来访问字典,访问不存在的key的时候不会报错,可以设置一个默认值返回,如果不传入default参数,就会默认返回None。

print(a.get(“c”))
None
print(a.get(1001, 0))
0

1.4 删除元素

a = {“name”:“Tome”}
del a[“name”]

删除不存在的key会报错,可以用"name" in a来测试一下

if “name” in a:
del a[“name”]

1.5 迭代字典

iteritems()和items()基本一样效果,但数量大的话,iteritems()性能会更好,所以一般默认用前者就好。通过下面的方式去迭代元素。

for key, val in a.iteritems():
print(key, val)

1.6 字典推导式

顾名思义和列表推导式差不多。直接看例子

a = [{“name”:“Tom”, “vote_num”: 1}, {“name”: “Mary”, “vote_num”:2}]

直接生成个字典,保存了名字和票数的关系。这样从数据库查出来记录后,直接这样生成一个字典方便查询对应的关键数据

b = {row.get(“name”): row.get(“vote_num”, 0) for row in a}
{“Tom”: 1, “Mary”: 2}

1.7 获取字典数量

len(d)

1.8 判断key是否在字典里面

官方建议用in或者not in,不推荐使用has_key()了,因为前者语法更简洁。对于新手小白想更轻松的学好Python基础,Python爬虫,web开发、大数据,数据分析,人工智能等技术,这里给大家分享系统教学资源,架下我尉♥: 2763177065 【教程/工具/方法/解疑】

if “name” in a:
print(“exists name”)
else:
print(“not exists name”)

1.9 用另一个字典覆盖当前字典

update()这个方法很常用,往往我们不想直接在原字典上面修改或者想覆盖另一个字典多项值就会用到了,这个方法没有返回值,经常有人用错了。

a = {“a”:1}
a.update({“a”: 2, “b”:1})
print(a)
{“a”:2, “b”:1}

错误用法

a = a.update({“a”:2 , “b”:1})

1.10 获取键列表

keys()和iterkeys()都是获取键列表,后者性能更好,一般推荐使用后者

for key in a.iterkeys():
print(key, a.get(key))

1.11 获取值列表:

values()和itervalues()获取值列表,同理上面

for val in a.itervalues():
print(val)

1.12 获取元组列表

items()和iteritems()获取一个键值对列表[(key1, val1), (key2, val2)],一般配合循环使用。

强调一下在使用这些iter前缀的函数的时候,在循环中都不要修改字典,因为这样会有问题。后面讲到迭代器和生成器再详细讲。
for循环出来的是无序的,如果想要按照插入的顺序输出用collections包的OrderedDict。

for key, val in a.iteritems():
print(key, val)

这个常用的例子就是想对字典的元素进行排序,再降序输出:

uid=>{“vote_num”: 1, “name”: “Tom”}

a = {“1000”: {“vote_num”: 1, “name”: “Tom”}, “1001”: {“vote_num”: 2, “name”: “Mary”}}
key_pairs = a.items()

lambda是个简短的函数表达式,v输入参数,冒号后面跟着是逻辑

按票数降序排序

key_pairs.sort(key=lambda v: v[1].get(“vote_num”, 0), reverse=True)
print(key_pairs)
[(“1001”, {“vote_num”: 2, “name”: “Mary”}), (“1000”, {“vote_num”: 1, “name”: “Tom”})]

然后按照票数降序输出

for (uid, info) in key_pairs:
print(“uid: {0} vote_num: {1}”.format(uid, info.get(“vote_num”, 0)))
uid: 1001 vote_num: 2
uid: 1000 vote_num: 1

  1. 应用例子: 统计票数

就以一个统计票数的例子来应用一下字典,虽然有Counter和defaultdict,但我觉得很多地方还是要用到dict的,把dict掌握了,前面两个其实就很好理解和使用。

例子和之前list的数据类似,需求是2个:

统计每天的总票数
想知道每天有哪些用户收到票的

数据文件

UID day vote_num
1000 2019_10_20 3
1000 2019_10_21 2
1001 2019_10_21 10
1001 2019_10_22 5

代码

import os
import sys
def main():
# 从命令行中获取文件名参数,argv[0]是程序文件名
fname = sys.argv[1]
# f是文件描述符
f = open(fname, “r”)
# 每天票数统计字典,key是日期字符串,value是总票数
day_num_dict = {}
# 每天用户统计字典,key是日期字符串,value是用户uid列表
day_uids_dict = {}
for i, line in enumerate(f):
# 第一行略过
if i == 0:
continue
uid, day, vote_num = line.strip().split(" ")
# map函数循环每个元素,把元素传进int()方法作为参数,最后赋值给uid,和vote_num
uid, vote_num = map(int, [uid, vote_num])
# 记录每天的票数
# 如果已经有这个票数记录
if day in day_num_dict:
day_num_dict[day] += vote_num
else:
day_num_dict[day] = vote_num
# 记录uid
# 如果不在dict有初始化,必须先初始化一个列表
if day not in day_uids_dict:
day_uids_dict[day] = []
# 养成良好习惯,后面必定加else
else:
pass
uids = day_uids_dict.get(day,[])
uids.append(uid)
# 输出每天的总票数
for day, vnum in day_num_dict.iteritems():
print(day, vnum)
# 输出每天有哪些用户uid
for day, uids in day_uids_dict.iteritems():
print(day, uids)

代码解释:

从命令行读取参数和从文件读取数据前面已经提过了
day_num_dict和day_uids_dict这两个分别保存了每天的总票数和每天的uid列表。
day_num_dict用in语句来判断是否已经有这个key,没有先初始化,有的话就直+=,当然推荐使用defauiltdict,不需要判断是否有这个key都可以直接使用+=。
day_uids_dict就是不能用defaultdict来替代的,每个key对应一个list,所以想直接day_num_dict[day].append(vote_num)是不行的,所以还是得先判断存在了不。
if..else..语句后面再谈,养成良好的习惯,加else结尾就不容易出错。

代码运行结果:

(‘2019_10_22’, 5)
(‘2019_10_21’, 12)
(‘2019_10_20’, 3)
(‘2019_10_22’, [1001])
(‘2019_10_21’, [1000, 1001])
(‘2019_10_20’, [1000])

最后提一种黑科技,很多时候key都不止一个uid,假如我想快速查到某个用户某天的票数呢,这里key就涉及了两个元素,uid和day,那如何是好呢?在使用Redis的时候也可以用同样的原理。有些人会用多个字典,但我觉得字典里面嵌入字典来查比较麻烦,下面这种直观易懂。

其实就是把两个元素用分隔符隔开,变成一个字符串,多个元素也没关系

key = “{0}_{1}”.format(“1000”, “2019_10_24”)
a = {}
a[key] = 10

获取票数

uid = 1000
day = “2019_10_24”
cur_key = “{0}_{1}”.format(uid, day)
print(a.get(key))

这篇关于【python教程入门学习】基础篇: 4. Python按图索骥的字典dict的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/767107

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os