Python代码阅读(第13篇):检测列表中的元素是否都一样
Posted Felix
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python代码阅读(第13篇):检测列表中的元素是否都一样相关的知识,希望对你有一定的参考价值。
Python 代码阅读合集介绍:为什么不推荐Python初学者直接看项目源码
本篇阅读的代码实现了检测列表中的元素是否都一样的逻辑。
本篇阅读的代码片段来自于30-seconds-of-python。
all_equal
def all_equal(lst):
return lst[1:] == lst[:-1]
# EXAMPLES
all_equal([1, 2, 3, 4, 5, 6]) # False
all_equal([1, 1, 1, 1]) # True
all_equal
函数接收一个列表,并判断列表中的各个元素是否都一样,如果一样就返回True
否则返回false
。
该函数采用的判断方式比较巧妙,将原列表去除第一个元素之后的子列表和原列表去除最后一个元素子列表进行对比。也就是原列表的元素进行了错位比较,元素从头到尾依次进行比较。
[a[0], a[1], ... a[n-1]] == [a[1], a[2], ... a[n]]
a[0] == a[1], a[1] == a[2], ... a[n-1] == a[n]
a[0] == a[1] == a[2] ... a[n-1] == a[n]
列表切片
lst[1:]
和lst[:-1]
是列表切片的形式。lst[1:]
表示从列表lst
下标为1
的元素开始一直到列表lst
最后一个元素的子列表。lst[:-1]
则是从第一个元素(下标为0
)开始直至列表的倒数第二个元素。
一般而言列表切片的形式是lst[a:b]
。a
和b
代表了列表的索引。lst[a:b]
返回的子列表从索引a
开始,直到索引b
的前一个元素停止。省略a
或者b
代表了“从头开始”或“直到列表结尾”。lst[:]
会返回整个列表的切片。负数索引返回离列表末尾相应距离的元素,-1
指的是列表最后一个元素。
Python代码阅读(第40篇):通过两个列表生成字典
Python 代码阅读合集介绍:为什么不推荐Python初学者直接看项目源码
本篇阅读的代码实现了使用两个列表中的元素分别作为key
和value
生成字典。
本篇阅读的代码片段来自于30-seconds-of-python。
to_dictionary
def to_dictionary(keys, values):
return {key:value for key, value in zip(keys, values)}
# EXAMPLES
to_dictionary([\'a\', \'b\'], [1, 2]) # { a: 1, b: 2 }
to_dictionary
函数接收两个列表作为key
和value
,返回由这两个列表的元素组成的字典。
函数使用字典推导式生成新的字典,使用列表key
中的元素作为字典的键,使用列表value
中对应的元素作为对应的值。推导式使用zip
函数同时迭代两个列表,获取两个列表中相对应的元素。
zip(*iterables)
创建一个聚合了来自每个可迭代对象中的元素的迭代器。它返回一个元组的迭代器,其中的第i
个元组包含来自每个参数序列或可迭代对象的第i
个元素。 当所输入可迭代对象中最短的一个被耗尽时,迭代器将停止迭代。 当只有一个可迭代对象参数时,它将返回一个单元组的迭代器。不带参数时,它将返回一个空迭代器。
>>> x = [1, 2, 3]
>>> y = [4, 5, 6]
>>> zipped = zip(x, y)
>>> list(zipped)
[(1, 4), (2, 5), (3, 6)]
以上是关于Python代码阅读(第13篇):检测列表中的元素是否都一样的主要内容,如果未能解决你的问题,请参考以下文章