python基础学习笔记第五章
一、数据容器入门1. 定义一种可容纳多份数据的Python数据类型每份数据为元素元素可以是任意类型字符串、数字、布尔等。2. 分类按特性划分依据是否支持重复元素、是否可修改、是否有序分为5类list(列表)、tuple(元组)、str(字符串)、set(集合)、dict(字典)。3. 核心优势替代多个独立变量实现批量存储/使用数据简洁高效。二、列表list- 可修改、有序、可重复1. 定义# 普通定义 name_list [itheima, itcast, python] # 多类型嵌套 my_list [itheima, 666, True, [1,2,3]] # 空列表 empty_list [] empty_list2 list()2. 下标索引正向从0开始递增反向从-1开始递减嵌套列表多层下标访问my_list [[1,2,3], [4,5,6]] print(my_list[0]) # 取内层第一个列表[1,2,3] print(my_list[0][0]) # 取内层第一个列表的第一个元素13. 常用方法方法作用代码示例append(元素)尾部追加元素my_list.append(7)extend(容器)尾部追加另一个容器的所有元素my_list.extend([8,9])insert(下标, 元素)指定下标插入元素my_list.insert(1, test)del 列表[下标]删除指定下标元素del my_list[0]pop(下标)删除指定下标元素并返回该元素val my_list.pop(0)remove(元素)删除第一个匹配的元素my_list.remove(666)clear()清空列表my_list.clear()count(元素)统计元素出现次数num my_list.count(1)index(元素)查找元素下标找不到报错idx my_list.index(itheima)len(列表)统计元素个数l len(my_list)4. 遍历while循环my_list [1,2,3,4,5] index 0 while index len(my_list): print(my_list[index]) index 1for循环my_list [1,2,3,4,5] for i in my_list: print(i)5. 特点可容纳多个元素上限支持多类型元素、嵌套有序有下标、可重复可修改增/删/改元素三、元组tuple- 不可修改、有序、可重复1. 定义注意单个元素必须加逗号否则不是元组类型# 普通定义 t1 (1, Hello, True) # 单个元素 t2 (Hello,) # 嵌套元组 t3 ((1,2,3), (4,5,6)) # 空元组 t4 () t5 tuple()2. 常用方法仅查询/统计无修改方法t (1,2,hello,3,4,hello) print(t.index(hello)) # 查找下标2 print(t.count(hello)) # 统计次数2 print(len(t)) # 统计个数6 print(t[2]) # 下标取值hello3. 特殊修改规则元组本身不可修改但内部的列表可以修改不可替换列表t (1,2,[itheima,itcast]) t[2][1] best # 合法修改列表内元素结果(1,2,[itheima,best]) # t[2] [1,2,3] # 非法替换列表报错4. 遍历同列表while/for循环均可t (1,2,3,4,5) # for循环推荐 for i in t: print(i)5. 特点与列表几乎一致唯一区别不可修改支持多类型、嵌套、有序、可重复适合存储不希望被篡改的数据四、字符串str- 不可修改、有序、字符专属容器1. 本质字符的有序容器每个字符对应下标仅能存储字符串类型。2. 下标索引同列表/元组正向0开始反向-1开始s itheima print(s[0]) # i print(s[-1]) # a3. 常用方法方法作用代码示例index(子串)查找子串下标找不到报错s.index(the)replace(子串1, 子串2)替换所有子串1为子串2返回新字符串new_s s.replace(i, I)split(分隔符)按分隔符分割返回列表lst s.split(e)strip()去除首尾空格/换行符new_s s.strip()strip(字符)去除首尾指定字符按单个字符匹配new_s 12itheima21.strip(12)count(子串)统计子串出现次数num s.count(i)len(字符串)统计字符个数中文/数字/符号均算1个l len(s)4. 遍历同列表/元组while/for循环均可s 黑马程序员 for c in s: print(c)5. 特点专属字符存储仅支持字符串类型有序、可重复、不可修改长度无限制取决于内存五、序列切片 - 列表/元组/字符串通用1. 序列定义内容连续、有序、支持下标索引的容器列表、元组、字符串。2. 切片语法序列[起始下标:结束下标:步长]起始下标留空从头开始结束下标留空截取到结尾不含结束下标本身步长1逐个取N跳过N-1个负数倒序取3. 示例# 列表切片 lst [1,2,3,4,5] print(lst[1:4]) # [2,3,4]1到3步长1 print(lst[::2]) # [1,3,5]从头到尾步长2 print(lst[3:1:-1]) # [4,3]倒序3到2 # 字符串切片倒序常用 s 12345 print(s[::-1]) # 54321完全倒序 # 元组切片 t (1,2,3,4,5) print(t[:1:-2]) # (5,3)倒序尾到2步长2六、集合set- 可修改、无序、不可重复自动去重1. 定义注意空集合必须用set(){}是空字典# 普通定义自动去重 s {黑马程序员, 传智播客, 黑马程序员} # 空集合 empty_s set()2. 常用方法无下标不可用while遍历方法作用代码示例add(元素)添加元素重复则忽略s.add(itheima)remove(元素)删除元素不存在报错s.remove(传智播客)pop()随机删除一个元素并返回val s.pop()clear()清空集合s.clear()difference(集合2)取差集本集合有集合2无返回新集合s3 s1.difference(s2)difference_update(集合2)本集合删除与集合2的交集修改原集合s1.difference_update(s2)union(集合2)取并集返回新集合s3 s1.union(s2)len(集合)统计元素个数l len(s)3. 遍历仅支持for循环无序遍历结果不固定s {1,2,3,4,5} for i in s: print(i)4. 特点可容纳多类型元素、可修改无序无下标、不可重复自动去重适合去重、交集/并集/差集计算七、字典dict- 可修改、无序、键值对形式1. 定义用{}存储键值对Key: ValueKey不可重复重复会覆盖Key不可为字典。# 普通定义 stu_score {王力鸿:99, 周杰轮:88, 林俊节:77} # 嵌套字典值为字典 stu_info { 王力鸿: {语文:77, 数学:66}, 周杰轮: {语文:88, 数学:86} } # 空字典 empty_dict {} empty_dict2 dict()2. 取值通过Key取值而非下标print(stu_score[王力鸿]) # 99 print(stu_info[王力鸿][语文]) # 773. 常用方法方法作用代码示例字典[Key] Value新增/更新键值对Key不存在新增存在更新stu_score[张学油]66pop(Key)删除键值对返回Valueval stu_score.pop(王力鸿)clear()清空字典stu_score.clear()keys()获取所有Key返回可迭代对象keys stu_score.keys()len(字典)统计键值对个数l len(stu_score)4. 遍历仅支持for循环默认遍历Key可通过Key取Valuestu_score {王力鸿:99, 周杰轮:88, 林俊节:77} # 遍历Key for key in stu_score: print(f学生{key}分数{stu_score[key]}) # 先取所有Key再遍历等价上式 for key in stu_score.keys(): print(f学生{key}分数{stu_score[key]})5. 特点存储键值对通过Key快速检索ValueKey唯一、不可为字典Value可任意类型/嵌套无序无下标、可修改适合存储有映射关系的数据如姓名-成绩、ID-信息八、数据容器通用操作所有5类容器均支持以下操作部分有专属限制如集合/字典无下标。1. 通用统计lst [1,2,3,4,5] s itheima print(len(lst)) # 统计元素个数5 print(max(s)) # 取最大元素t字符串按ASCII码比较 print(min(lst)) # 取最小元素12. 通用类型转换lst [1,2,3] t (4,5,6) s 789 se {1,2,3} # 转列表 print(list(t)) # [4,5,6] # 转元组 print(tuple(lst)) # (1,2,3) # 转字符串 print(str(lst)) # [1,2,3] # 转集合自动去重 print(set(lst)) # {1,2,3}3. 通用排序# sorted(容器, reverseTrue/False)返回排好序的列表 lst [5,2,9,1] s bacfe print(sorted(lst)) # 升序[1,2,5,9] print(sorted(lst, reverseTrue)) # 降序[9,5,2,1] print(sorted(s)) # 字符串按ASCII排序[a,b,c,e,f]4. 通用遍历支持for循环所有容器均支持支持while循环仅列表、元组、字符串有下标集合、字典不支持无下标九、5类数据容器核心对比特性列表list元组tuple字符串str集合set字典dict元素类型任意任意仅字符任意Key除字典外任意Value任意下标索引支持支持支持不支持不支持重复元素支持支持支持不支持Key不重复Value可重复可修改性支持不支持不支持支持支持数据有序是是是否否核心使用场景可修改、可重复的批量数据不可修改、可重复的批量数据字符序列存储数据去重、集合运算键值对映射快速检索十、经典练习代码1. 列表筛选偶数whilefor双实现# 原列表 nums [1,2,3,4,5,6,7,8,9,10] even_lst [] # while循环实现 index 0 while index len(nums): if nums[index] % 2 0: even_lst.append(nums[index]) index 1 print(fwhile筛选偶数{even_lst}) # for循环实现 even_lst2 [] for i in nums: if i % 2 0: even_lst2.append(i) print(ffor筛选偶数{even_lst2})2. 集合去重my_list [黑马程序员, 传智播客, 黑马程序员, itcast, itcast] my_set set() # 遍历列表添加到集合自动去重 for i in my_list: my_set.add(i) print(f去重后集合{my_set})3. 字典升职加薪# 员工信息字典 staff { 王力鸿: {部门:科技部, 工资:3000, 级别:1}, 周杰轮: {部门:市场部, 工资:5000, 级别:2}, 张学油: {部门:科技部, 工资:4000, 级别:1} } # 遍历所有员工级别1则升职加薪 for name in staff: if staff[name][级别] 1: staff[name][级别] 1 staff[name][工资] 1000 print(f加薪后信息{staff})4. 序列切片取指定内容# 原字符串万过薪月员序程马黑来nohtyP学 s 万过薪月员序程马黑来nohtyP学 # 步骤1倒序字符串 → 学Python来黑马程序员月薪过万 s_rev s[::-1] # 步骤2切片取黑马程序员 result s_rev[9:14] # 切片不包含最后一个下标 print(f结果{result}) # 黑马程序员
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2427214.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!