《小甲鱼零基础入门学习Python》自学笔记(三)—— 字典、集合、文件部分

2024-02-01 14:30

本文主要是介绍《小甲鱼零基础入门学习Python》自学笔记(三)—— 字典、集合、文件部分,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

字典、集合、文件部分

一、字典(dict)

字典是映射类型

(1)创造和访问字典

关键符号:{}
:”前:键(key)
:”后:值(value)
eg:

>>> dict1 = {'李宁':'一切皆有可能', '耐克':'Just do it', '阿迪达斯':'Impossible is noting', '鱼C工作室':'让编程改变世界'}
>>> print('鱼C工作室的口号是:', dict1['鱼C工作室'])
鱼C工作室的口号是: 让编程改变世界

eg:

>>> dict2 = {1:'one', 2:'two', 3:'three'}
>>> dict2[2]
'two'

(2)字典的方法:

fromkeys(s[,v]):创建并返回一个新的字典
eg:

>>> dict1 = {}
>>> dict1.fromkeys((1, 2, 3))
{1: None, 2: None, 3: None}
>>> dict1.fromkeys((1, 2, 3), 'Number')
{1: 'Number', 2: 'Number', 3: 'Number'}

keys():访问字典的键
eg:

>>> dict1 = {1: 'Number', 2: 'Number', 3: 'Number'}
>>> for eachKey in dict1.keys():print(eachKey)1
2
3

values():访问字典的值
items():访问字典的项(键和值)
get():访问字典的值(更灵活),键可以不在字典中
eg:

>>> dict1 = {1: 'Number', 2: 'Number', 3: 'Number'}
>>> dict1[4]				# 会报错
Traceback (most recent call last):File "<pyshell#35>", line 1, in <module>dict1[4]
KeyError: 4
>>> dict1.get(4)			# 不会报错
>>> print(dict1.get(4))
None
>>> dict1.get(4,'无')		# 可以设置键不在字典中时的输出
'无'
>>> dict1.get(3,'无')		# 当键在字典中,正常输出该键对应的值
'Number'

如果不知道一个键是否在字典中,可以用成员资格操作符来判断。innot in

>>> 3 in dict1
True
>>> 4 in dict2
False

注意:成员资格操作符在字典中查找的是键,不是值;而在序列中查找的是元素的值,不是索引号。

clear():清空字典
copy():浅拷贝
pop():弹出值,参数:键
popitem():弹出一项(键和值) 字典没有一定的顺序,可以理解为随机弹出
setdefault():与get()类似,但当键不在字典中时,会自动添加进去

>>> dict1 = {1: 'Number', 2: 'Number', 3: 'Number'}
>>> dict1.setdefault(4)
>>> dict1
{1: 'Number', 2: 'Number', 3: 'Number', 4: None}
>>> dict1.setdefault(5, 'Five')
'Five'
>>> dict1
{1: 'Number', 2: 'Number', 3: 'Number', 4: None, 5: 'Five'}

update():更新

>>> dict1
{1: 'Number', 2: 'Number', 3: 'Number', 4: None, 5: 'Five'}
>>> dict2 = {2:'Two'}
>>> dict1.update(dict2)
>>> dict1
{1: 'Number', 2: 'Two', 3: 'Number', 4: None, 5: 'Five'}

二、集合(set)

集合里的元素具有唯一性,自动清除重复的数据
集合是无序的

(1)创建:
直接把一堆元素用“{}”括起来

>>> num = {1, 2, 3, 4, 4, 5, 5}
>>> num
{1, 2, 3, 4, 5}

使用set()工厂函数

>>> set1 = set([1, 3, 5, 7, 9])
>>> set1
{1, 3, 5, 7, 9}

(2)访问集合中的值:
可以使用for把集合中的数据一个个读取出来
可以通过innot in判断一个元素是否在集合中已经存在

(3)方法:

>>> num
{1, 2, 3, 4, 5}
>>> num.add(6)
>>> num
{1, 2, 3, 4, 5, 6}
>>> num.remove(5)
>>> num
{1, 2, 3, 4, 6}

集合类型内建方法总结:
https://fishc.com.cn/forum.php?mod=viewthread&tid=45276&extra=page%3D1%26filter%3Dtypeid%26typeid%3D403

(4)不可变集合:
frozenset():创建一个不可变集合

>>> num2 = frozenset([1, 2, 3, 4, 5])
>>> num2.add(0)
Traceback (most recent call last):File "<pyshell#12>", line 1, in <module>num2.add(0)
AttributeError: 'frozenset' object has no attribute 'add'

三、文件(file)

扩展名:.exe .txt .ppt .jpg .mp4 .avi等

(1)文件打开模式:

在这里插入图片描述

‘x’ 和 ‘w’ 均是以“可写入”的模式打开文件

(2)文件对象方法:

在这里插入图片描述

注意:字节和字符是不同的!

打印文件的每一行:

for each_line in f:print(each_line)

文件的写入:

>>> f = open('D:\\test.txt', 'w')
>>> f.write('Hello,World!')
12
>>> f.close()

四、文件系统

模块是一个包含所有你定义的函数和变量的文件,其后缀名是.py。
模块可以被别的程序引入,以使用该模块中的函数等功能。

OS:Operating System 操作系统
有了OS模块,我们不需要关心什么操作系统下使用什么模块,OS模块会帮你选择正确的模块并调用。

osos.path 模块中关于文件、目录常用的函数使用方法
https://fishc.com.cn/forum.php?mod=viewthread&tid=45512&extra=page%3D1%26filter%3Dtypeid%26typeid%3D403

五、永久存储

pickle模块

存放:pickling
读取:unpickling

eg:
存放:

>>> import pickle								# 导入
>>> my_list = [123, 3.14, 'Percy', ['another list']]
>>> pickle_file = open('my_list.pkl', 'wb')			# 创建并打开文件
>>> pickle.dump(my_list, pickle_file)				# 把数据倒入文件
>>> pickle_file.close()							# 关闭文件

读取:

>>> pickle_file = open('my_list.pkl', 'rb')			# 打开文件
>>> my_list2 = pickle.load(pickle_file)				# 加载文件中的数据
>>> my_list2
[123, 3.14, 'Percy', ['another list']]

这篇关于《小甲鱼零基础入门学习Python》自学笔记(三)—— 字典、集合、文件部分的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及