Python 代码浏览合集介绍:为什么不举荐Python初学者间接看我的项目源码

本篇浏览的代码实现了在一个列表中每距离n个数取一个元素的性能。

本篇浏览的代码片段来自于30-seconds-of-python。

every_nth

def every_nth(lst, nth):  return lst[nth - 1::nth]# EXAMPLESprint(every_nth([1, 2, 3, 4, 5, 6], 2)) # [ 2, 4, 6 ]

every_nth函数接管一个列表和距离数nth,返回列表的取值后果。

函数应用列表切片的形式,获取原列表每距离nth个元素取值的后果。

s[i:j:k]的模式是sij步长为k的切片。sij步长为k的切片被定义为所有满足0 <= n < (j-i)/k的索引号x = i + n*k的项组成的序列。 换句话说,索引号为i,i+k,i+2*k,i+3*k,以此类推,当达到j时进行 (但肯定不包含j)。 当k为正值时,ij会被减至不大于len(s)。 当k为负值时,ij会被减至不大于len(s) - 1。 如果ij被省略或为None,它们会定义为列表一端能够达到的“终止”值 (是哪一端的终止值则取决于k的符号)。 请留神,k不可为零。 如果k 为None,则当作1解决。

因为列表的索引是从0开始的,所以第一个被取出的数的索引是nth-1。因为j被省略,所以会始终计算到列表的末端。咱们应用一个不那么“恰好”的例子看一下:

>>> every_nth([1, 2, 3, 4, 5, 6, 7], 2) # [ 2, 4, 6 ][2, 4, 6]