我们对于列表的抓取已经有所了解,不过光会从列表中获取元素这还远远不够。假设列表元素的顺序是随机的,这时候我们想要获取元素,还是先对列表进行排序比较好。相信重新排好顺序的列表,对于我们的使用和接下来进行其它的代码操作都能简便不少,这里我们要使用shuffle()函数来帮助我们完成,下面是一些shuffle()函数对列表排序的使用。
shuffle()函数是将列表的所有元素随机排序。
有时候我们的任务中会使用到随机sample一个数据集的某些数,比如一个文本中,有10行,我们需要随机选取前5个。
那么我们就可以采取shuffle()函数,然后list中放入1-10个行号,利用shuffle()函数之后,序号就打乱了。
这个时候,我们选取前5个元素即可。就起到了随机打乱的结果了。
代码:
# -*- coding: UTF-8 -*- #代码功能是测试一下shuffle()函数 import random number = [] for index in range(1,11): number.append(index) random.shuffle(number) for index in range(5): print number[index]
通过 Fisher-Yates 算法对新列表进行排序,该算法会打乱列表元素的顺序:
from copy import deepcopy from random import randint def shuffle(lst): temp_lst = deepcopy(lst) m = len(temp_lst) while (m): m -= 1 i = randint(0, m) temp_lst[m], temp_lst[i] = temp_lst[i], temp_lst[m] return temp_lst foo = [1,2,3] shuffle(foo) # [2,3,1] , foo = [1,2,3]
以上就是用shuffle()函数对列表元素排序的一些操作方法,之后有遇到对列表排序的操作,都可以优先考虑下random的shuffle怎么用,说不定就能轻松解决了呢。
神龙|纯净稳定代理IP免费测试>>>>>>>>天启|企业级代理IP免费测试>>>>>>>>IPIPGO|全球住宅代理IP免费测试