日 - 列表功能
时间:2025-01-06 17:54:52 147浏览 收藏
你在学习文章相关的知识吗?本文《日 - 列表功能》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!
Python 列表提供了丰富的操作方法,本文将重点介绍 extend()
、append()
、insert()
、reverse()
、sort()
和 sorted()
等方法,并结合示例讲解其用法。此外,还将演示如何查找列表中的最小值、最大值、第二小值和第二大值,以及 in
和 not in
运算符的使用,最后以字符串反转和冒泡排序算法为例,进一步巩固列表操作技巧。
列表扩展与追加:
extend()
: 将可迭代对象(如列表、元组)的所有元素添加到列表末尾。
l1 = [10, 20, 30]
l2 = [40, 50, 60]
l1.extend(l2)
print(l1) # 输出: [10, 20, 30, 40, 50, 60]
print(len(l1)) # 输出: 6
append()
: 将单个元素添加到列表末尾。注意,append()
添加的是整个元素,而不是元素的各个组成部分。
l1 = [10, 20, 30]
l2 = [40, 50, 60]
l1.append(l2)
print(l1) # 输出: [10, 20, 30, [40, 50, 60]]
print(len(l1)) # 输出: 4
insert()
: 在列表指定索引处插入单个元素。
l1 = [10, 20, 30]
l1.insert(1, 15) # 在索引 1 处插入 15
print(l1) # 输出: [10, 15, 20, 30]
append()
和 extend()
的区别:append()
添加的是一个元素,而 extend()
添加的是多个元素。
l1 = [10, 20, 30]
l1.append('abcd')
print(l1) # 输出: [10, 20, 30, 'abcd']
l1.extend('pqrs')
print(l1) # 输出: [10, 20, 30, 'abcd', 'p', 'q', 'r', 's']
列表反转与排序:
reverse()
: 就地反转列表元素顺序。
l1 = [10, 20, 30]
l1.reverse()
print(l1) # 输出: [30, 20, 10]
sort()
: 就地排序列表元素(默认升序)。
l1 = [10, 200, 30]
l1.sort()
print(l1) # 输出: [10, 30, 200]
l1.sort(reverse=True)
print(l1) # 输出: [200, 30, 10]
sorted()
: 返回一个新的已排序列表,不修改原始列表。
my_list = [3, 1, 4, 5, 2]
sorted_list = sorted(my_list)
print(sorted_list) # 输出: [1, 2, 3, 4, 5]
print(my_list) # 输出: [3, 1, 4, 5, 2]
列表统计函数:
min()
: 查找最小值。max()
: 查找最大值。sum()
: 查找所有元素的和。
l1 = [10, 200, 30, 40, 50]
print(min(l1)) # 输出: 10
print(max(l1)) # 输出: 200
print(sum(l1)) # 输出: 330
使用 float('inf')
和 -float('inf')
分别表示正无穷和负无穷,可以方便地查找第二小值和第二大值:
l1 = [10, 20, 310, 40, 50]
min_value = float('inf')
second_min = float('inf')
for x in l1:
if x < min_value:
second_min = min_value
min_value = x
elif x < second_min and x != min_value:
second_min = x
print(second_min) # 输出: 20
l1 = [10, 20, 30, 40, 50]
max_value = -float('inf')
second_max = -float('inf')
for x in l1:
if x > max_value:
second_max = max_value
max_value = x
elif x > second_max and x != max_value:
second_max = x
print(second_max) # 输出: 40
成员运算符:
in
: 检查元素是否在列表中。not in
: 检查元素是否不在列表中。
l1 = [100, 67, 54, 101, 220, 670, 45, 32]
print(100 in l1) # 输出: True
print(100 not in l1) # 输出: False
print(120 in l1) # 输出: False
print(120 not in l1) # 输出: True
字符串反转和冒泡排序:
字符串反转:
s = "today is thursday"
reverse = s[::-1] #利用切片反转
print(reverse) # 输出: yadruht si yadot
冒泡排序 (示例:升序排列):
l1 = [40, 30, 20, 10]
n = len(l1)
for i in range(n):
for j in range(0, n-i-1):
if l1[j] > l1[j+1]:
l1[j], l1[j+1] = l1[j+1], l1[j]
print(l1) # 输出: [10, 20, 30, 40]
通过以上示例,您可以更深入地理解 Python 列表的各种操作方法,并能够灵活运用它们来解决实际问题。 记住,选择合适的方法可以显著提高代码效率和可读性。
理论要掌握,实操不能落!以上关于《日 - 列表功能》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
246 收藏
-
436 收藏
-
387 收藏
-
151 收藏
-
435 收藏
-
185 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习