python3 0基础学习----数据结构(基础+练习)
python 0基础学习笔记之数据结构
- 📚 几种常见数据结构
- 列表 (List)
- 1. 定义
- 2. 实例:
- 3. 列表中常用方法
- .append(要添加内容) 向列表末尾添加数据
- .extend(列表) 将可迭代对象逐个添加到列表中
- .insert(索引,插入内容) 向指定位置插入内容
- .remove(删除内容) 删除指定内容
- .pop(索引) 删除指定索引处内容并返回删除内容
- .index(要查询内容) 返回一个与制定元素匹配的索引,不改变原列表
- .count(要查询内容) 返回列表中该元素出现次数
- .sort() 同类型排序(默认升序),不同类型会报错TypeError: '<' not supported between instances of 'int' and 'str'
- .reverse() 反向排序,不分类型
- 元组(Tuple)
- 1. 定义
- 2. 实例:
- 元组输出的是列表的子集
- 3. 元组中常用方法
- .index(element) 返回第一个与制定元素相等的元素的索引
- .count(要查询内容) 返回列表中该元素出现次数
- 修改元组内容
- 字典(Dictionary)
- 1. 定义
- 2. 实例:
- 3. 字典中常用方法
- in和not in方法
- for 键 in 字典
- for in 和items()结合使用
- .keys() 返回一个包含字典所有`键`的视图
- .values() 返回一个包含字典所有`值`的视图
- get(key, default):返回指定键的值,如果键不存在,则返回默认值(default)。
- .pop(key):移除指定键的键值对,并返回键对应的值。
- .popitem():随机移除并返回一个键值对
- .update(): 使用其他字典内容更新当前字典
- .clear():移除字典中的所有键值对。
- .items() : 用于以键-值对(key-value pairs)
- 集合(Set)
- 1. 定义
- 2. 实例:
- 3. 集合常用方法
- .add(element)向集合`随机`添加元素(因为无序所以随机)
- .remove(element)从集合中删除某元素,如果该集合没有该元素返回错误KeyError
- .discard(element)从集合中删除某元素,如果该集合没有该元素也不会报错
- .pop()随机移初一个元素,并返回该元素(集合是无序的,无法确定删除的元素是那个)
- .clear() 清除集合中所有元素,输出set()
- .copy():复制一个集合
- 字符串(String)
- 1. 定义
- 2. 实例:
- 3. 集合常用方法
- 📚 常用的内置函数
- 1. print(): 将制定的值输出到控制台
- 2. len(sequence): 返回序列的长度(元素个数)
- 3. type(object): 返回对象的类型
- 4. input('请输入') : 获取用户输入数据
- 5. range(初值, 终值, 步长)内置函数,返回的是一个可迭代对象。用于创建数字序列
- 6. int(x)、float(x)、str(x)、bool(x) 等:将输入值转换为整数、浮点数、字符串或布尔值类型。
- 7. max(iterable)、min(iterable):返回可迭代对象中的最大值和最小值。
- 8. sum() 返回可迭代对象的和(用于数组类型的对象)
- 9. abs(x):返回数值的绝对值。
- 10. round(number, ndigits):将数值四舍五入到指定的小数位数
- 11. dir() 函数不带参数时,返回当前范围内的变量、方法和定义的类型列表;带参数时,返回参数的属性、方法列表
- 📚 结合实战练习
- 1. 列表中in和not in 的使用
- 练习2 :读取a.txt文件,对每一行使用split()方法拆分为单词列表,对每一行单词进行筛选去重复,添加到新的列表中。最后使用sort()进行排序。(大概意思是提取a.txt中出现过的单词生成一个列表)
- 1. a.txt文件内容(请忽略内容是什么意思,网上是那个随便找的)
- 2. 提取单词思路
- 3. 代码:
- 4. 输出结果
- 练习2 :读取一份邮件,获取到邮件中出现过的单词生成字典,并记录每个地址出现过的个数
- 1. a.txt内容和上一题一样
- 2. 思路
- 3. 代码
- 4. 运行结果
- 练习3 :在练习2中升级,输出练习2中,单词出现最多的建和键值
📚 几种常见数据结构
列表 (List)
1. 定义
列表是一种有序的可变序列
,可以包含不同类型的元素。列表可以通过方括号 []
来表示,元素之间用逗号分隔
。
注释: 注意列表可变,字符串不可变,只能改变大小写
2. 实例:
my_list = [1, 'hello', 3.14, True]
3. 列表中常用方法
.append(要添加内容) 向列表末尾添加数据
.extend(列表) 将可迭代对象逐个添加到列表中
.insert(索引,插入内容) 向指定位置插入内容
.remove(删除内容) 删除指定内容
.pop(索引) 删除指定索引处内容并返回删除内容
.index(要查询内容) 返回一个与制定元素匹配的索引,不改变原列表
.count(要查询内容) 返回列表中该元素出现次数
.sort() 同类型排序(默认升序),不同类型会报错TypeError: ‘<’ not supported between instances of ‘int’ and ‘str’
.reverse() 反向排序,不分类型
元组(Tuple)
1. 定义
元组是一种有序的不可变序列
,同样可以包含不同类型的元素。元组可以通过圆括号 ()
来表示,元素之间用逗号分隔
。
2. 实例:
my_tuple = (1, 'hello', 3.14, True)
元组输出的是列表的子集
3. 元组中常用方法
因为元组是不可修改的所以只能查询,如果要修改得先转换成列表进行修改,之后在转换成元组
x = (1,5,'i','j')
# x.sort() #报错 AttributeError: 'tuple' object has no attribute 'sort'
print(x[1]) #输出: 5
x[1] = 6 #报错 TypeError: 'tuple' object does not support item assignment
.index(element) 返回第一个与制定元素相等的元素的索引
.count(要查询内容) 返回列表中该元素出现次数
修改元组内容
字典(Dictionary)
1. 定义
字典是一种键值对
的集合,键和值可以是任意的数据类型。字典可以通过花括号 {}
来表示,每个键值对使用冒号 : 分隔
,键值对之间用逗号分隔
。可做内容修改
a={age:10}
a['age']=18
print(a) #输出 {'age': 18}
字典里边没有顺序 ,列表有从0开始
字典是直接删除重新加入,所以没有顺序
2. 实例:
my_dict = {'name': 'John', 'age': 25, 'city': 'New York'}
3. 字典中常用方法
in和not in方法
a={'age':10,'name':'xiaoming'}
print('name' in a) #输出 True
print('s' not in a) #输出 True
for 键 in 字典
可以通过dict(健)=键值
for in 和items()结合使用
for 健,键值 in 字典.items()
a = {'age':10,'name':'xiaoming'}
for (k,v) in a.items(): #()可加可不加print(k,v)
print(k,v) 输出:
age 10
name xiaoming
.keys() 返回一个包含字典所有键
的视图
.values() 返回一个包含字典所有值
的视图
get(key, default):返回指定键的值,如果键不存在,则返回默认值(default)。
.pop(key):移除指定键的键值对,并返回键对应的值。
.popitem():随机移除并返回一个键值对
.update(): 使用其他字典内容更新当前字典
.clear():移除字典中的所有键值对。
.items() : 用于以键-值对(key-value pairs)
my_dict = {'name': 'Alice', 'age': 25, 'city': 'New York'}
items = my_dict.items()
print(items)
输出: dict_items([(‘name’, ‘Alice’), (‘age’, 25), (‘city’, ‘New York’)])
集合(Set)
1. 定义
集合是一种无序的
、不重复
的元素的集合。集合可以通过花括号 {} 或 set() 函数来创建
。
2. 实例:
my_set = {1, 2, 3, 4, 5}
3. 集合常用方法
.add(element)向集合随机
添加元素(因为无序所以随机)
.remove(element)从集合中删除某元素,如果该集合没有该元素返回错误KeyError
.discard(element)从集合中删除某元素,如果该集合没有该元素也不会报错
.pop()随机移初一个元素,并返回该元素(集合是无序的,无法确定删除的元素是那个)
.clear() 清除集合中所有元素,输出set()
.copy():复制一个集合
字符串(String)
1. 定义
字符串是一种由字符组成的不可变序列
,可以用单引号或双引号括
起来
2. 实例:
my_string = 'Hello, World!'
3. 集合常用方法
上篇文章有写,跳转地址python3 0基础学习----基本知识
📚 常用的内置函数
1. print(): 将制定的值输出到控制台
print('hi~') #输出 hi~
2. len(sequence): 返回序列的长度(元素个数)
3. type(object): 返回对象的类型
4. input(‘请输入’) : 获取用户输入数据
5. range(初值, 终值, 步长)内置函数,返回的是一个可迭代对象。用于创建数字序列
for num in range(5):print(num) # 输出: 0, 1, 2, 3, 4for num in range(2, 7):print(num) # 输出: 2, 3, 4, 5, 6for num in range(1, 10, 2):print(num) # 输出: 1, 3, 5, 7, 9
6. int(x)、float(x)、str(x)、bool(x) 等:将输入值转换为整数、浮点数、字符串或布尔值类型。
num1 = int("10")
num2 = float("3.14")
text = str(42)
flag = bool(1)
7. max(iterable)、min(iterable):返回可迭代对象中的最大值和最小值。
my_list = [3, 1, 5, 2, 4]
max_value = max(my_list)
min_value = min(my_list)
print(max_value) #输出 5
print(min_value) #输出 1
8. sum() 返回可迭代对象的和(用于数组类型的对象)
9. abs(x):返回数值的绝对值。
s = abs(-10)
print(s) #输出 10
10. round(number, ndigits):将数值四舍五入到指定的小数位数
rounded_num = round(3.14159, 2)
print(rounded_num) #输出3.14
11. dir() 函数不带参数时,返回当前范围内的变量、方法和定义的类型列表;带参数时,返回参数的属性、方法列表
>>>dir() # 获得当前模块的属性列表
['__builtins__', '__doc__', '__name__', '__package__', 'arr', 'myslice']
>>> dir([ ]) # 查看列表的方法
['__add__', '__class__', '__contains__', '__delattr__', '__delitem__', '__delslice__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getslice__', '__gt__', '__hash__', '__iadd__', '__imul__', '__init__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__rmul__', '__setattr__', '__setitem__', '__setslice__', '__sizeof__', '__str__', '__subclasshook__', 'append', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort']
>>>
📚 结合实战练习
1. 列表中in和not in 的使用
some = [1,2,3,4,5,6]
print(3 in some) #输出 True
print(3 not in some) #输出 False
练习2 :读取a.txt文件,对每一行使用split()方法拆分为单词列表,对每一行单词进行筛选去重复,添加到新的列表中。最后使用sort()进行排序。(大概意思是提取a.txt中出现过的单词生成一个列表)
1. a.txt文件内容(请忽略内容是什么意思,网上是那个随便找的)
Dear Sir/Madam,
I am writing this email to express my gratitude to you and to discuss
some matters. I hope this email finds you in good health and high
spirits.Firstly, I would like to sincerely thank you for your generosity and
assistance. I have been facing some difficulties in pursuing my career
goals, and your support has been invaluable to me. Your advice and
guidance have helped me gain a better understanding of the challenges
I have faced and have motivated me to continue striving.The purpose of this email is to request a meeting with you in order to
personally express my gratitude. I would like the opportunity to
showcase the progress I have made in my professional development and
to hear your valuable insights. If you are willing, I can arrange the
meeting according to your convenience, and the location and date can
be adjusted according to your preferences.Furthermore, I wanted to inquire if there is anything else I can do
for you. Your generosity may have an impact not only on me personally
but also on other individuals I may be able to assist. Please let me
know if there is anything you need help with, as I would be more than
happy to offer my assistance.Once again, thank you for your support and generosity, and I hold
great expectations for the future. I sincerely look forward to meeting
with you and expressing my gratitude in person. If you have any
questions or require further information regarding the meeting, please
feel free to contact me.With heartfelt appreciation,
[Your Name]
2. 提取单词思路
遍历文件每行内容
拆分每行内容为单词列表
遍历当前行列表单词
查找list中是否存在当前单词,存在记录出现个数,不存在新增一条记录
3. 代码:
th = open('a.txt')
print('读取文件内容',th)
lst = list()#空列表
for item in th:itemStr = item.rstrip()# 去除末尾空白符号pList = itemStr.split()# 以空格作为分隔符分割每行数据,返回一个单词列表 ,例如首行:['Dear', 'Sir/Madam,']for word in pList:if len(lst)==0:lst.append(word)continueif len(lst)>0:if lst.count(word)>0:continueelse:lst.append(word)print('列表长度',len(lst))
lst.sort()
print(lst)
4. 输出结果
练习2 :读取一份邮件,获取到邮件中出现过的单词生成字典,并记录每个地址出现过的个数
1. a.txt内容和上一题一样
2. 思路
读取文件
声明空字典
遍历文件内容
去掉每行结尾空白符号
切割每行生成单词字典
3. 代码
th = open('a.txt')
dictStr = dict()#空字典
for item in th:itemStr = item.rstrip()# 去除末尾空白符号pDict = itemStr.split()# 以空格作为分隔符分割每行数据,返回一个单词列表 ,例如首行:['Dear', 'Sir/Madam,']for word in pDict:dictStr[word] = dictStr.get(word,0)+1 #查找。找到获取对应值+1,没找到默认为0+1
# print(dictStr.items())#items方法,返回可迭代对象的(key,value)
print(sorted([(k,v) for k,v in dictStr.items()]))
4. 运行结果
练习3 :在练习2中升级,输出练习2中,单词出现最多的建和键值
bigKey = None #最大键
bigValue = None #最大键值
for k,v in dictStr.items():if bigKey is None or v>bigValue: # is判断是否相等,or或bigValue = vbigKey = k
print(bigKey,':',bigValue)
输出结果:to : 17
相关文章:

python3 0基础学习----数据结构(基础+练习)
python 0基础学习笔记之数据结构 📚 几种常见数据结构列表 (List)1. 定义2. 实例:3. 列表中常用方法.append(要添加内容) 向列表末尾添加数据.extend(列表) 将可迭代对象逐个添加到列表中.insert(索引,插入内容) 向指定…...
计算机科学中的“旅行商问题”
题目:旅行商问题(Traveling Salesman Problem) 当初为何收藏:我收藏了这个题目是因为它是一个经典而富有挑战性的组合优化问题,涉及到计算机科学、算法设计和实际应用领域。我认为这个问题可以展示出算法设计的重要性…...

QT:自定义控件(Connect使用,子控件连接)
自定义控件封装: 1.添加新文件(设计师界面类),创建子页面 ,放自己想要的控件 2.在主页面中使用子控件 :新建一个widget- ISO21434 组织网络安全管理(二) ISO21434 项目网络安全管理(三) ISO21434 分布式网络安全(四) SO21434 持续进行的网络安全(五) ISO21434 概念阶段网络安全(六)...

Visual Studio 如何放大代码字体的大小
1.打开Visual Studio,新建一个程序,一段代码,为接下去的操作做好准备。单击菜单栏的【工具】选项。 2.在跳出来菜单中找到【选项】(一般在最后一项),然后单击。跳出新的窗口。 3.跳出新的窗口后ÿ…...

Verilog同步FIFO设计
同步FIFO(synchronous)的写时钟和读时钟为同一个时钟,FIFO内部所有逻辑都是同步逻辑,常常用于交互数据缓冲。 异步FIFO:数据写入FIFO的时钟和数据读出FIFO的时钟是异步的(asynchronous) 典型同步FIFO有三部分组成: (1࿰…...
Php“牵手”lazada商品详情页数据采集方法,lazadaAPI接口申请指南
lazada详情接口 API 是开放平台提供的一种 API 接口,它可以帮助开发者获取商品的详细信息,包括商品的标题、描述、图片等信息。在电商平台的开发中,详情接口API是非常常用的 API,因此本文将详细介绍详情接口 API 的使用。 一、la…...

Sentinel 规则持久化
文章目录 Sentinel 规则持久化一、修改order-service服务1.引入依赖2.配置nacos地址 第二步修改非常麻烦,可以略过,直接使用已经打好包的来使用二、修改sentinel-dashboard源码1. 解压2. 修改nacos依赖3. 添加nacos支持4. 修改nacos地址5. 配置nacos数据…...

元宇宙时代超高清视音频技术白皮书关于流媒体协议和媒体传输解读
流媒体协议 元宇宙业务场景对流媒体传输的实时性和互动性提出了更高的要求,这就需要在传统的 RTMP、SRT、 HLS 等基础上增加实时互动的支持。实时互动,指在远程条件下沟通、协作,可随时随地接入、实时地传递虚实融合的多维信息,身…...

【计算机设计大赛】国赛一等奖项目分享——基于多端融合的化工安全生产监管可视化系统
文章目录 一、计算机设计大赛国赛一等奖二、项目背景三、项目简介四、系统架构五、系统功能结构六、项目特色(1)多端融合(2)数据可视化(3)计算机视觉(目标检测) 七、系统界面设计&am…...

深入理解【二叉树】
📙作者简介: 清水加冰,目前大二在读,正在学习C/C、Python、操作系统、数据库等。 📘相关专栏:C语言初阶、C语言进阶、C语言刷题训练营、数据结构刷题训练营、有感兴趣的可以看一看。 欢迎点赞 👍…...

RequestRespons
文章目录 Request&Respons1 Request和Response的概述2 Request对象2.1 Request继承体系2.2 Request获取请求数据2.2.1 获取请求行数据2.2.2 获取请求头数据2.2.3 获取请求体数据2.2.4 获取请求参数的通用方式 2.3 IDEA快速创建Servlet2.4 请求参数中文乱码问题2.4.1 POST请…...
UniApp 使用命令创建页面的详细指南
系列文章目录 文章目录 系列文章目录前言一、安装Uni-CLI二、创建页面三、页面创建命令四、页面结构五、页面使用总结 前言 UniApp是一款跨平台的前端框架,可以用于开发同时运行在多个平台(如微信小程序、H5、App等)的应用程序。本文将详细介…...
Opencv 图像的读取与写入
目录 导入cv2 读取图像数据 创建一个窗口 waitKey方法 关闭所有窗口 完整示例 保存图片 示例 导入cv2 # 导入opencv包 import cv2 读取图像数据 cv2.imread(path, flag) 参数说明: path:要读取的图像文件的路径。 flag(可选&#…...
关于rinex3.x广播星历文件中时间系统的说明
文章目录 rinex广播星历文件介绍广播星历介绍rinex3.x多系统广播星历文件中的时间系统写在最后 rinex广播星历文件介绍 rinex星历文件是一种ascii字符文件,可以存放广播星历和精密星历,被广泛用于GNSS数据处理。 本文主要介绍广播星历文件。 对于rinex…...
Ansible 实战
Ansible 实战 1. httpd 角色 目录 rootubuntu1904:~#tree -f httpd/ httpd ├── httpd/default │ └── httpd/default/main.yml ├── httpd/files │ ├── httpd/files/httpd.conf │ └── httpd/files/index.html ├── httpd/handlers │ └── http…...
三、单元测试
三、单元测试 好的单元测试必须遵守 AIR 原则 A:Automatic(自动化)I:Independent(独立性)R:Repeatable(可重复) 单元测试应该是全自动执行的,并且非交互式的…...

“Spring管理JavaBean的过程及Bean的生命周期“
目录 引言1.弹簧容器2. Bean的生命周期2.1 配置javaBean2.2. 解析Bean的定义2.3 检查是否需要添加自己的功能2.4 初始化2.5 实现Aware接口2.6 扩展2.7. 销毁 3. 单例模式和原型模式3.1. 单例模式3.2. 原型模式 4. 总结 引言 Spring框架是一个非常流行的Java应用程序框架&#…...

@mouseover不起作用,并没有触发
我的错误代码如下: <el-rowv-for"version in item.version_list":key"version.id":class"{ blue-background: versionItem.id version.id }"mouseover.native"version.isHovered true"mouseleave.native"version…...
Vue 2 组件注册
组件名的命名规则 定义组件名的两种方式: 短横线分隔命名,Kebab Case,例如my-component-name。单词首字母大写命名,Pascal Case,例如MyComponentName。 第一种方式在模板中使用<my-component-name>引用该元素…...
Python|GIF 解析与构建(5):手搓截屏和帧率控制
目录 Python|GIF 解析与构建(5):手搓截屏和帧率控制 一、引言 二、技术实现:手搓截屏模块 2.1 核心原理 2.2 代码解析:ScreenshotData类 2.2.1 截图函数:capture_screen 三、技术实现&…...

MODBUS TCP转CANopen 技术赋能高效协同作业
在现代工业自动化领域,MODBUS TCP和CANopen两种通讯协议因其稳定性和高效性被广泛应用于各种设备和系统中。而随着科技的不断进步,这两种通讯协议也正在被逐步融合,形成了一种新型的通讯方式——开疆智能MODBUS TCP转CANopen网关KJ-TCPC-CANP…...
C++ 基础特性深度解析
目录 引言 一、命名空间(namespace) C 中的命名空间 与 C 语言的对比 二、缺省参数 C 中的缺省参数 与 C 语言的对比 三、引用(reference) C 中的引用 与 C 语言的对比 四、inline(内联函数…...
三体问题详解
从物理学角度,三体问题之所以不稳定,是因为三个天体在万有引力作用下相互作用,形成一个非线性耦合系统。我们可以从牛顿经典力学出发,列出具体的运动方程,并说明为何这个系统本质上是混沌的,无法得到一般解…...
【生成模型】视频生成论文调研
工作清单 上游应用方向:控制、速度、时长、高动态、多主体驱动 类型工作基础模型WAN / WAN-VACE / HunyuanVideo控制条件轨迹控制ATI~镜头控制ReCamMaster~多主体驱动Phantom~音频驱动Let Them Talk: Audio-Driven Multi-Person Conversational Video Generation速…...

安全突围:重塑内生安全体系:齐向东在2025年BCS大会的演讲
文章目录 前言第一部分:体系力量是突围之钥第一重困境是体系思想落地不畅。第二重困境是大小体系融合瓶颈。第三重困境是“小体系”运营梗阻。 第二部分:体系矛盾是突围之障一是数据孤岛的障碍。二是投入不足的障碍。三是新旧兼容难的障碍。 第三部分&am…...
LangChain知识库管理后端接口:数据库操作详解—— 构建本地知识库系统的基础《二》
这段 Python 代码是一个完整的 知识库数据库操作模块,用于对本地知识库系统中的知识库进行增删改查(CRUD)操作。它基于 SQLAlchemy ORM 框架 和一个自定义的装饰器 with_session 实现数据库会话管理。 📘 一、整体功能概述 该模块…...
Vite中定义@软链接
在webpack中可以直接通过符号表示src路径,但是vite中默认不可以。 如何实现: vite中提供了resolve.alias:通过别名在指向一个具体的路径 在vite.config.js中 import { join } from pathexport default defineConfig({plugins: [vue()],//…...

android RelativeLayout布局
<?xml version"1.0" encoding"utf-8"?> <RelativeLayout xmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"match_parent"android:layout_height"match_parent"android:gravity&…...
土建施工员考试:建筑施工技术重点知识有哪些?
《管理实务》是土建施工员考试中侧重实操应用与管理能力的科目,核心考查施工组织、质量安全、进度成本等现场管理要点。以下是结合考试大纲与高频考点整理的重点内容,附学习方向和应试技巧: 一、施工组织与进度管理 核心目标: 规…...