Python 中为什么 list.reverse() 返回 None
list.reverse()
方法返回 None 因为它改变了原始列表。 在 Python 中,大多数就地改变对象的方法都返回 None 。
a_list = ['fql', 'jiyik', '.', 'com']
result = a_list.reverse()
print(result) # 👉️ None
print(a_list) # 👉️ ['com', '.', 'jiyik', 'fql']
list.reverse()
方法原地反转列表的元素。
该方法返回 None 因为它改变了原始列表。
这是 Python 中的一种约定,用于将原始对象变异为返回 None 的方法。
如果我们想反转列表而不改变它,请使用 reversed()
函数。
a_list = ['fql', 'jiyik', '.', 'com']
result = list(reversed(a_list))
print(result) # 👉️ ['com', '.', 'jiyik', 'fql']
print(a_list) # 👉️ ['fql', 'jiyik', '.', 'com']
reversed
函数接受一个迭代器,将其反转并返回结果。
该函数将反向列表作为迭代器返回,因此我们必须使用
list()
类将迭代器转换为列表。
reversed()
函数不会改变原始列表。 原始列表保持不变。
如果不需要保留原始列表,也可以重新分配变量。
a_list = ['fql', 'jiyik', '.', 'com']
a_list = list(reversed(a_list))
print(a_list) # 👉️ ['com', '.', 'jiyik', 'fql']
或者,我们可以使用步长为 -1 的列表切片语法来反转列表并返回结果。
a_list = ['fql', 'jiyik', '.', 'com']
result = a_list[::-1]
print(result) # 👉️ ['com', '.', 'jiyik', 'fql']
print(a_list) # 👉️ ['fql', 'jiyik', '.', 'com']
列表切片的语法是 my_list[start:stop:step]
。
start 索引是包含的,stop 索引是排他的(直到,但不包括)。
如果省略 start 索引,则认为它为 0,如果省略 stop 索引,则切片转到列表的末尾。
我们使用步长 -1 来反转列表。 当使用负步长时,我们选择从列表末尾到开头的每个第 N 个元素。
负索引可用于向后计数,例如 my_list[-1]
返回列表中的最后一项,my_list[-2]
返回倒数第二项。
如果不需要保留原始列表,可以重新分配 a_list 变量。
a_list = ['fql', 'jiyik', '.', 'com']
a_list = a_list[::-1]
print(a_list) # 👉️ ['com', '.', 'jiyik', 'fql']
print(a_list) # 👉️ ['com', '.', 'jiyik', 'fql']
不要尝试将调用 reverse()
、append()
、insert()
或 extend()
的结果分配给变量,因为改变原始对象的方法通常返回 None。
大多数时候,我们可以将鼠标悬停在 IDE 中的方法上以查看方法的返回值。
如果一个方法返回 None,那么它会在适当的位置改变一个对象。
相反,大多数返回 None 以外的值的方法通常返回一个新对象并且不会改变原始对象。
相关文章
Python pandas.pivot_table() 函数
发布时间:2024/04/24 浏览次数:82 分类:Python
-
Python Pandas pivot_table()函数通过对数据进行汇总,避免了数据的重复。
在 Python 中将 Pandas 系列的日期时间转换为字符串
发布时间:2024/04/24 浏览次数:894 分类:Python
-
了解如何在 Python 中将 Pandas 系列日期时间转换为字符串
在 Python Pandas 中使用 str.split 将字符串拆分为两个列表列
发布时间:2024/04/24 浏览次数:1124 分类:Python
-
本教程介绍如何使用 pandas str.split() 函数将字符串拆分为两个列表列。
在 Pandas 中将 Timedelta 转换为 Int
发布时间:2024/04/23 浏览次数:231 分类:Python
-
可以使用 Pandas 中的 dt 属性将 timedelta 转换为整数。
Python 中的 Pandas 插入方法
发布时间:2024/04/23 浏览次数:112 分类:Python
-
本教程介绍了如何在 Pandas DataFrame 中使用 insert 方法在 DataFrame 中插入一列。
使用 Python 将 Pandas DataFrame 保存为 HTML
发布时间:2024/04/21 浏览次数:106 分类:Python
-
本教程演示如何将 Pandas DataFrame 转换为 Python 中的 HTML 表格。
如何将 Python 字典转换为 Pandas DataFrame
发布时间:2024/04/20 浏览次数:73 分类:Python
-
本教程演示如何将 python 字典转换为 Pandas DataFrame,例如使用 Pandas DataFrame 构造函数或 from_dict 方法。
如何在 Pandas 中将 DataFrame 列转换为日期时间
发布时间:2024/04/20 浏览次数:101 分类:Python
-
本文介绍如何将 Pandas DataFrame 列转换为 Python 日期时间。