
Python 列表提供了丰富的操作方法,本文将重点介绍 extend()、append()、insert()、reverse()、sort() 和 sorted() 等方法,并结合示例讲解其用法。此外,还将演示如何查找列表中的最小值、最大值、第二小值和第二大值,以及 in 和 not in 运算符的使用,最后以字符串反转和冒泡排序算法为例,进一步巩固列表操作技巧。
列表扩展与追加:
extend(): 将可迭代对象(如列表、元组)的所有元素添加到列表末尾。<code class="python">l1 = [10, 20, 30] l2 = [40, 50, 60] l1.extend(l2) print(l1) # 输出: [10, 20, 30, 40, 50, 60] print(len(l1)) # 输出: 6</code>
append(): 将单个元素添加到列表末尾。注意,append() 添加的是整个元素,而不是元素的各个组成部分。<code class="python">l1 = [10, 20, 30] l2 = [40, 50, 60] l1.append(l2) print(l1) # 输出: [10, 20, 30, [40, 50, 60]] print(len(l1)) # 输出: 4</code>
insert(): 在列表指定索引处插入单个元素。<code class="python">l1 = [10, 20, 30] l1.insert(1, 15) # 在索引 1 处插入 15 print(l1) # 输出: [10, 15, 20, 30]</code>
append() 和 extend() 的区别:append() 添加的是一个元素,而 extend() 添加的是多个元素。
<code class="python">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']</code>列表反转与排序:
reverse(): 就地反转列表元素顺序。<code class="python">l1 = [10, 20, 30] l1.reverse() print(l1) # 输出: [30, 20, 10]</code>
sort(): 就地排序列表元素(默认升序)。<code class="python">l1 = [10, 200, 30] l1.sort() print(l1) # 输出: [10, 30, 200] l1.sort(reverse=True) print(l1) # 输出: [200, 30, 10]</code>
sorted(): 返回一个新的已排序列表,不修改原始列表。<code class="python">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]</code>
列表统计函数:
min(): 查找最小值。max(): 查找最大值。sum(): 查找所有元素的和。<code class="python">l1 = [10, 200, 30, 40, 50] print(min(l1)) # 输出: 10 print(max(l1)) # 输出: 200 print(sum(l1)) # 输出: 330</code>
使用 float('inf') 和 -float('inf') 分别表示正无穷和负无穷,可以方便地查找第二小值和第二大值:
<code class="python">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</code>成员运算符:
in: 检查元素是否在列表中。not in: 检查元素是否不在列表中。<code class="python">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</code>
字符串反转和冒泡排序:
字符串反转:
<code class="python">s = "today is thursday" reverse = s[::-1] #利用切片反转 print(reverse) # 输出: yadruht si yadot</code>
冒泡排序 (示例:升序排列):
<code class="python">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]</code>通过以上示例,您可以更深入地理解 Python 列表的各种操作方法,并能够灵活运用它们来解决实际问题。 记住,选择合适的方法可以显著提高代码效率和可读性。
以上就是日 - 列表功能的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号