random--生成伪随机数

标签: Python 模块


random是Python内建函数,作用是产生随机数
1.导入模块:

import random

2.random模块下的函数

  • random.seed(a=None, version=2)

伪随机数生成模块。如果a为None,默认使用系统时间。若使用相同的a,则可以获得相同的随机数序列。

>>> import random 
>>> a = random.seed(1)
>>> [random.randint(1,100) for i in range(20)]
[18, 73, 98, 9, 33, 16, 64, 98, 58, 61, 84, 49, 27, 13, 63, 4, 50, 56, 78, 98]
>>> b = random.seed(1)
>>> [random.randint(1,100) for i in range(20)]
[18, 73, 98, 9, 33, 16, 64, 98, 58, 61, 84, 49, 27, 13, 63, 4, 50, 56, 78, 98]
  • random.random()

生成一个0~1之间的随机浮点数(包括0不包括1)。

>>> random.random()
0.767157629147962
  • rondom.ranint(a, b)

生成一个a到b(包括a与b)之间的随机整数,a、b必须为整数。

>>> random.randint(1,10)
8
  • random.uniform(a, b)

生成一个a,b之间的随机浮点数(不考虑a,b的大小)。

>>> random.uniform(2.5,0.0)
2.0045659174912087
  • random.choice(seq)

从非空序列seq中返回一个随机元素。如果seq为空,则引发IndexError

 >>> random.choice([1,2,3,4,5]) #list
1
>>> random.choice('helloworld') #字符串
'l'
>>> random.choice(['hello','world']) #字符串列表
'hello'
>>> random.choice((1,2,3,4,5)) #元组
4
  • random.choices(population, weights=None, *, cum_weights=None, k=1)

从population中选择出k个值组成一个新的序列,可以设置相对权重weights和累计权重cum_weights,权重越高被选择到的概率就越大
如果没有指定weightscum_weights,则选择的概率相等。如果提供了权重序列,它必须与群体序列的长度相同weightscum_weights可以使用任何数值类型(包括整数,浮点数,和分数)。

>>> random.choices(['red', 'black', 'green'], [18, 18, 2], k=6)
['black', 'green', 'black', 'black', 'black', 'black']
  • random.randrange(start, stop, step)

生成一个从start到stop(不包括stop),间隔为step的一个随机整数。start、stop、step都要为整数。

>>> random.randrange(0, 100, 3)
42
  • random.shuffle(x)

将序列x随机混合,直接改变原有的序列,random.shuffle() 是用来打乱列表元素的,没有返回值

>>> a=[1,2,3,4,5,6] 
>>> random.shuffle(a)
>>> a
[1, 6, 4, 5, 2, 3]
  • random.sample(seq, k)

从序列或集合中选择的唯一元素长度为k的列表。用于无需更换的随机抽样。

>>> a=[1,2,3,4,5,6]
>>> random.sample(a, 3)
[1, 4, 6]

3.伪随机
为什么说random是伪随机?
根据我的理解,random所产生的数其实也是根据一定的计算得到的,并不是实际意义上的随机数。伪就是还是有规律的,只是数量体大到在正常情况下无法印证其非随机性,然则实际上还是会重现重复。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 最近在写个性化推荐的论文,经常用到Python来处理数据,被pandas和numpy中的数据选取和索引问题绕的比较...
    shuhanrainbow阅读 10,046评论 6 19
  • 方法1 (数据类型)(最小值+Math.random()*(最大值-最小值+1)) 例: (int)(1+Math...
    GB_speak阅读 41,372评论 2 6
  • 记得结婚第二年第一个纪念日前夫一脸茫然的样子。也许从七年前开始就注定了这是我一个人的婚姻。 今天是一个死祭也是一个...
    昍猫阅读 1,648评论 0 0
  • 花花 花花,不是华晨宇。而是,我们这一批学员中有两个花花,大花...
    遇见苏小州阅读 1,801评论 0 0
  • 上周,因为家里有事,离开两天。三年多来,第一次和儿子分开。那两天,有点漫长。 离开的前一天晚上,想提前给他一些暗示...
    孙晓丽阅读 3,114评论 0 1

友情链接更多精彩内容