Python中怎么随机打乱列表排序

Python 中怎么随机打乱列表排序,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

创新互联建站凭借在网站建设、网站推广领域领先的技术能力和多年的行业经验,为客户提供超值的营销型网站建设服务,我们始终认为:好的营销型网站就是好的业务员。我们已成功为企业单位、个人等客户提供了成都网站制作、网站设计、外贸网站建设服务,以良好的商业信誉,完善的服务及深厚的技术力量处于同行领先地位。

 

场景:

现在有一个list:[1,2,3,4,5,6],我需要把这个list在输出的时候,是以一种随机打乱的形式输出。

专业点的术语:将一个容器中的数据每次随机逐个遍历一遍。

注意:不是生成一个随机的list集。

 

环境:

Python 3.6

 

解决方案:

 

方案一:

有人可能会通过Random内置函数,来间接实现想要的结果。但是这种方式,太原始,也不够优雅,而且有种重复造轮子的嫌疑。这里我就不贴我自己通过random实现的效果了。

 

方案二:

Random中有一个random.shuffle()方法提供了完美的解决方案。代码如下:

x = [1,2,3,4,5,6]random.shuffle(x)print(x)
 

输出结果:

第一次输出内容:[6, 5, 1, 3, 2, 4]第二次输出内容:[6, 1, 3, 5, 2, 4]第三次输出内容:[5, 3, 1, 2, 4, 6]
 

从结果我们可以看出,输出是完全随机的,代码量就两行,不需要random,不需要for循环。

 

源码解读:

此部分原文链接:Python中打乱列表顺序 random.shuffle()的使用方法[1]

def shuffle(self, x, random=None):    """Shuffle list x in place, and return None.    原位打乱列表,不生成新的列表。
   Optional argument random is a 0-argument    function returning a random float in [0.0, 1.0);    if it is the default None,    the standard random.random will be used. 可选参数random是一个从0到参数的函数,返回[0.0,1.0)中的随机浮点; 如果random是缺省值None,则将使用标准的random.random()。    """
   if random is None:        randbelow = self._randbelow        for i in reversed(range(1, len(x))):            # pick an element in x[:i+1] with which to exchange x[i]            j = randbelow(i + 1)            x[i], x[j] = x[j], x[i]    else:        _int = int        for i in reversed(range(1, len(x))):            # pick an element in x[:i+1] with which to exchange x[i]            j = _int(random() * (i + 1))            x[i], x[j] = x[j], x[i]

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。


分享名称:Python中怎么随机打乱列表排序
文章分享:http://scyanting.com/article/jdidgc.html