热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

python源码中的学习笔记_第4章_列表

列表基础##主题:列表基础#if__name____main__:#列表中可以存储多个元素,每个元素的数据类型可以不相同#每个元素指向不同的对象&

列表基础

#
# 主题:列表基础
#if __name__ == '__main__':# 列表中可以存储多个元素,每个元素的数据类型可以不相同# 每个元素指向不同的对象,不同的对象存储不同类型的数据myList = ['hello', True, 98]print( id(myList)) # 输出 2686147977800print( type(myList)) # 输出 print(myList) # 输出 ['hello', True, 98]

创建列表

#
# 主题:列表基础
#if __name__ == '__main__':# 列表中可以存储多个元素,每个元素的数据类型可以不相同# 每个元素指向不同的对象,不同的对象存储不同类型的数据myList = ['hello', True, 98]print( id(myList)) # 输出 2686147977800print( type(myList)) # 输出 print(myList) # 输出 ['hello', True, 98]

列表的特点

在这里插入图片描述

#
# 主题:列表的特点
#if __name__ == '__main__':a = ['hello', True, 1]# 列表元素按顺序有序排序# 索引映射唯一数据print(a[0], a[-3])# 列表可以储存重复数据# 任意数据类型混存b = ['hello', True, 1, 1]print( list(b))# 系统会自动根据需要动态分配和回收内存

查询列表

#
# 主题:查询列表
#if __name__ == '__main__':a = ['hello', True, 2, True]# 获取列表中指定元素的索引print(a.index('hello')) # 输出 0print(a.index(True)) # 输出 1# 若列表中有若干相同的元素,则只返回相同元素的第一个元素的索引print(a.index(True)) # 输出 1# 若列表中没有要查询的元素,则报错 ValueError# index(要查找的元素, stop, end) 可以规定查询的范围为 [stop, end)print(a.index('hello', 0, 3)) # 输出 0print(a.index(1, 0, 3)) # 输出 1,因为 True 的值为 1# print(a.index(2, 0, 2)) # 元素 2 不在索引号 0~1 的范围内,会报错ValueError# 根据索引号获取列表中的单个元素print(a[3]) # 输出 Trueprint(a[-1]) # 输出 Trueprint(a[-4]) # 输出 hello# 若列表中没有要查询的索引,则报错 IndexError# 列表名[start: stop: step] 获取列表中多个元素(又称“切片”)# 列表名[start: stop] 查询范围[start, stop)# 切片得到的列表与愿列表是不同的对象,只不过两个有相同的元素a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]print(a[0: 2: 1])print(a[0: 2]) # 默认步长为 1print(a[0: 2:]) # 默认步长为 1print(a[ : 6: 2]) # 默认范围从第一个元素开始print(a[0: : 2]) # 默认范围到最后一个元素结束print(a[ : : -1]) # 默认范围为整个列表,步长为负数表明切片列表元素与原列表元素顺序相反print(a[9: : -1]) # 与上一句输出相同print(a[6: 0: -2])

列表元素的判断与遍历

#
# 主题:列表元素的判断与遍历
#if __name__ = '__main__':lst = [10, 20, 'python', 'hello']print(10 in lst)print(100 in lst)print(10 not in lst)print(100, not in lst)# 遍历列表元素for item in lst:print(item)

添加列表元素

#
# 主题:添加列表元素
#if __name__ == '__main__':lst = [10, 20, 30]lst.append(100) # 在原列表的后面添加新元素print(lst) # 添加元素后的列表与原列表是同一个对象lst2 = ['hello', 'world']lst.append(lst2) # lst2 作为对象,整体成为 lst 的一个元素print(lst) # [10, 20, 30, 100, ['hello', 'world']]lst.extend(lst2) # 获取 lst2 中每个数据,并按顺序添加到原数列的后面print(lst) # [10, 20, 30, 100, ['hello', 'world'], 'hello', 'world']lst.insert(1, '我在这') # 在规定的索引处添加自定义对象print(lst) # [10, '我在这', 20, 30, 100, ['hello', 'world'], 'hello', 'world']lst[1: : ] = ['a', 'b', 'c'] # 将原列表中规定范围内的元素删掉,再添加新的元素print(lst)

删除列表元素

#
# 主题:删除列表元素
#if __name__ == '__main__':lst = [1, 2, 3, 4, 5, 6, 7, 8, 9]lst.remove(4) # 删掉指定的元素# 若要删除的元素不在列表中,则报错 ValueErrorprint(lst) # [1, 2, 3, 5, 6, 7, 8, 9]lst.pop(1) # 删除指定索引上的元素# 若指定的索引超出列表的索引范围,则报错 IndexErrorprint(lst) # [1, 3, 5, 6, 7, 8, 9]lst.pop() # 未指定索引,则默认删除最后一个元素print(lst) # [1, 3, 5, 6, 7, 8]lst1 = lst[1: 3] # 该操作称为“切片”,lst1 与 lst 是不同的对象,即所对应的存储位置不同print(lst1) # [3, 5]print(lst) # [1, 3, 5, 6, 7, 8]lst[1: 3] = [] # 该操作前后,都是同一个对象,即 lstprint(lst) # [1, 6, 7, 8]lst.clear() # 清除列表中所有元素print(lst) # []lst.extend(['这', '是', '添', '加', '的', '内', '容'])print(lst) # ['这', '是', '添', '加', '的', '内', '容']del lst # 删除列表对象,删除了列表的内容和地址# print(lst) # 将报错 NameError,报错 lst 没有定义

修改列表元素

#
# 主题:修改列表元素
#if __name__ == "__main__":lst = [1, 2, 3, 4, 5, 6]lst[2] = 30 # 该操作修改了 lst[2] 上的引用# 原先 lst[2] 指向 3 所在对象,后来指向 30 所在对象print(lst) # [1, 2, 30, 4, 5, 6]lst[1: 3] = [300, 400, 500, 600]print(lst) # [1, 300, 400, 500, 600, 4, 5, 6]

排序列表元素

#
# 主题:排序列表元素
#if __name__ == '__main__':lst = [20, 40, 10, 98, 54]print('原列表:', lst)lst.sort() # 无参数,表明默认升序排序。相当于 lst.sort(reverse=False)# 排序时在原列表的基础上进行的,没有生成新的列表print('升序后:',lst) # [10, 20, 40, 54, 98]lst.sort(reverse=True)print('降序后:', lst) # [98, 54, 40, 20, 10]lst1 = sorted(lst) # 升序排序,产生新的列表对象print(lst1) # [10, 20, 40, 54, 98]lst1 = sorted(lst, reverse=True) # 降序排序,产生新列表对象print(lst1) # [98, 54, 40, 20, 10]

列表生成式(生成列表的公式)

#
# 主题:列表生成式(生成列表的公式)
#if __name__ == '__main__':lst = [i*i for i in range(1, 10)] # for i in range(1, 10) 是 i 的取值范围[1, 10)# i*i 是 lst 的通项(类比数学数列的概念)print(lst) # [1, 4, 9, 16, 25, 36, 49, 64, 81]

推荐阅读
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 本文详细介绍了Java中org.w3c.dom.Text类的splitText()方法,通过多个代码示例展示了其实际应用。该方法用于将文本节点在指定位置拆分为两个节点,并保持在文档树中。 ... [详细]
  • 本文详细介绍了 Apache Jena 库中的 Txn.executeWrite 方法,通过多个实际代码示例展示了其在不同场景下的应用,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 本文详细探讨了VxWorks操作系统中双向链表和环形缓冲区的实现原理及使用方法,通过具体示例代码加深理解。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文介绍如何使用Python进行文本处理,包括分词和生成词云图。通过整合多个文本文件、去除停用词并生成词云图,展示文本数据的可视化分析方法。 ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 本文深入探讨了 Python 列表切片的基本概念和实际应用,通过具体示例展示了不同切片方式的使用方法及其背后的逻辑。 ... [详细]
  • 本文介绍了如何在Python中使用join()方法将列表中的元素连接成一个字符串。join()方法允许用户指定分隔符,从而灵活地生成所需格式的字符串。此外,我们还将探讨一些实际应用中的注意事项和技巧。 ... [详细]
  • 本文介绍如何通过创建替代插入触发器,使对视图的插入操作能够正确更新相关的基本表。涉及的表包括:飞机(Aircraft)、员工(Employee)和认证(Certification)。 ... [详细]
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
  • 本文详细介绍了C语言中链表的两种动态创建方法——头插法和尾插法,包括具体的实现代码和运行示例。通过这些内容,读者可以更好地理解和掌握链表的基本操作。 ... [详细]
  • 深入理解Java泛型:JDK 5的新特性
    本文详细介绍了Java泛型的概念及其在JDK 5中的应用,通过具体代码示例解释了泛型的引入、作用和优势。同时,探讨了泛型类、泛型方法和泛型接口的实现,并深入讲解了通配符的使用。 ... [详细]
author-avatar
wuli空空以空空
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有