【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

相关文章

Python logging模块使用示例详解

《Pythonlogging模块使用示例详解》Python的logging模块是一个灵活且强大的日志记录工具,广泛应用于应用程序的调试、运行监控和问题排查,下面给大家介绍Pythonlogging模... 目录一、为什么使用 logging 模块?二、核心组件三、日志级别四、基本使用步骤五、快速配置(bas

Python日期和时间完全指南与实战

《Python日期和时间完全指南与实战》在软件开发领域,‌日期时间处理‌是贯穿系统设计全生命周期的重要基础能力,本文将深入解析Python日期时间的‌七大核心模块‌,通过‌企业级代码案例‌揭示最佳实践... 目录一、背景与核心价值二、核心模块详解与实战2.1 datetime模块四剑客2.2 时区处理黄金法

Python文件操作与IO流的使用方式

《Python文件操作与IO流的使用方式》:本文主要介绍Python文件操作与IO流的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、python文件操作基础1. 打开文件2. 关闭文件二、文件读写操作1.www.chinasem.cn 读取文件2. 写

使用Python自动化生成PPT并结合LLM生成内容的代码解析

《使用Python自动化生成PPT并结合LLM生成内容的代码解析》PowerPoint是常用的文档工具,但手动设计和排版耗时耗力,本文将展示如何通过Python自动化提取PPT样式并生成新PPT,同时... 目录核心代码解析1. 提取 PPT 样式到 jsON关键步骤:代码片段:2. 应用 JSON 样式到

python通过curl实现访问deepseek的API

《python通过curl实现访问deepseek的API》这篇文章主要为大家详细介绍了python如何通过curl实现访问deepseek的API,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编... API申请和充值下面是deepeek的API网站https://platform.deepsee

ubuntu20.0.4系统中安装Anaconda的超详细图文教程

《ubuntu20.0.4系统中安装Anaconda的超详细图文教程》:本文主要介绍了在Ubuntu系统中如何下载和安装Anaconda,提供了两种方法,详细内容请阅读本文,希望能对你有所帮助... 本文介绍了在Ubuntu系统中如何下载和安装Anaconda。提供了两种方法,包括通过网页手动下载和使用wg

Spring Boot集成SLF4j从基础到高级实践(最新推荐)

《SpringBoot集成SLF4j从基础到高级实践(最新推荐)》SLF4j(SimpleLoggingFacadeforJava)是一个日志门面(Facade),不是具体的日志实现,这篇文章主要介... 目录一、日志框架概述与SLF4j简介1.1 为什么需要日志框架1.2 主流日志框架对比1.3 SLF4

Spring Boot集成Logback终极指南之从基础到高级配置实战指南

《SpringBoot集成Logback终极指南之从基础到高级配置实战指南》Logback是一个可靠、通用且快速的Java日志框架,作为Log4j的继承者,由Log4j创始人设计,:本文主要介绍... 目录一、Logback简介与Spring Boot集成基础1.1 Logback是什么?1.2 Sprin

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

如何在Ubuntu上安装NVIDIA显卡驱动? Ubuntu安装英伟达显卡驱动教程

《如何在Ubuntu上安装NVIDIA显卡驱动?Ubuntu安装英伟达显卡驱动教程》Windows系统不同,Linux系统通常不会自动安装专有显卡驱动,今天我们就来看看Ubuntu系统安装英伟达显卡... 对于使用NVIDIA显卡的Ubuntu用户来说,正确安装显卡驱动是获得最佳图形性能的关键。与Windo