博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[python] random 模块 -- 生成随机数/打乱序列
阅读量:6292 次
发布时间:2019-06-22

本文共 2351 字,大约阅读时间需要 7 分钟。

hot3.png

random 模块是 python 自带模块中非常常用的一个模块,它可以产生许多随机化的操作。无论你是做网页开发,还是写普通的算法程序,随机数的生成都起到了很重要的作用。

1. 随机数种子 seed() 与 random() 函数

按照其他语言的惯例,在导入 random 模块之后,我们首先需要设定一个随机数种子 seed(num) 。其中 num 就是要设置的种子。为什么要设置随机数种子呢?其实计算机的随机数是一种“伪随机数”,它并不能做到真正的随机,而是用一种算法通过随机数种子计算出一个“随机的”序列。所以当随机数种子相同的时候,出现的随机数的序列是一样的。在设定了随机数种子后,我们就可以用 random() 函数来输出随机数。下面我们先演示随机数种子相同的情况:

import randomrandom.seed(3)print(random.random())

运行两次,输出结果是相同的

0.23796462709189137

0.23796462709189137

前面说其他语言使用 random() 前要定义随机数种子,但是 python 与其他语言不同。当你省去 seed() 中的参数时,它会自动使用系统当前时间作为种子,因为时间基本不会重复,所以就可以保证随机的唯一性(不会像指定种子那样会重复)。 python 中使用 random 模块时,还可以不加 seed() 这一语句,它也会自动将当前时间设置为随机数种子。所以我们测试下面的代码:

import randomprint(random.random())

可以看到,这样的话两次输出就不同了,表面上看起来就具备了随机性。

0.826457253856883

0.656398726587975

2. randint() 、 randrange() 、 uniform() 、 getgetrandbits()

细心的朋友可能会发现, random() 输出的值都在0-1之间,事实上它的取值范围是 [0, 1) 的浮点数,那么假如想要输出 [1,9] 的整数,要怎么办呢?

也许有的人会想到:

int(random.random() * 9) + 1

如果你想到了上面的代码,恭喜你,基础功不错。不过在 python 中,这就不够“简洁优雅”了。正确的使用方法是

random.randint(1, 9)

randint(a, b) 的作用是产生一个 [a, b] 的整数。与这个不同的是, randrange(m, n[, k = 1]) 这个函数可以产生一个 [m, n) 之间以 k 为步长的整数,其中参数 k 是可以省略的,默认值为1。使用上面几个函数时,要注意开闭区间

randint(a, b)randrange(m, n[, k = 1]) 这两个函数产生的都是整数。如果要随机产生一段区间的浮点数的话,就可以用 uniform(a, b) 这一个函数,它可以生成一个区间为 [a, b] 的随机小数。除此之外,还有一个 getrandbits(k) 的函数,它可以产生k比特长的随机整数,在使用固定位数16进制数或者2进制数时,这个函数将更加好用。

上面讲了这么多都是和生成随机数有关,不过 random 模块不仅仅能产生随机数,它还能实现更多的功能……

3. choice() 与 choices() - 随机选择

比如说你想做一个随机点名的程序,你将所有学生的姓名放在一个列表中。假如 random 模块只能实现生成随机数的功能的话,你还必须要将产生的随机数一一分配(比如说分配学号),这样并不直观。这个时候, python 就给我们提供了一个很好的选择 -- choice(seq) 。这个函数可以实现从一个列表中随机选择一个内容并返回。例如以下的代码:

import randomls = ['David', 'Mike', 'Jack']print(random.choice(ls))

David

如果要选出多个元素的话,只需要在 choice 后面加个 s ,choices(seq[, k = 1]) ,其中seq仍为待输入的序列,在后加 k = n 则可以挑选出 n 个元素生成一个新的列表。不过这个元素是会重复的。下面就遇到了这个问题:

import randomls = ['David', 'Mike', 'Jack']print(random.choices(ls,k = 2))
['Jack', 'Jack']

4. shuffle() - 随机打乱一个序列

接下来就是一个更有趣的函数了, shuffle(seq) ,它可以将一个序列打乱。注意它会将数列原地打乱,意思就是说,运行完毕后 seq 保存的就是打乱后的序列,而将这个函数的结果直接输出或者赋值给其他变量都是不可行的。

错误 用法:

import randomls = ['David', 'Mike', 'Jack']print(random.shuffle(ls))

返回值是 None ,所以正确用法为

import randomls = ['David', 'Mike', 'Jack']random.shuffle(ls)print(ls)

返回值是 ['Mike', 'Jack', 'David']

结语与其他文档

以上就是本教程的全部内容了。 random 模块还有其他拓展的内容,包括以上介绍的 choicesshuffle 函数都还有额外的参数可供选择。具体可以参考 。

转载于:https://my.oschina.net/u/3729927/blog/1926611

你可能感兴趣的文章
dojo.mixin(混合进)、dojo.extend、dojo.declare
查看>>
Python 数据类型
查看>>
iOS--环信集成并修改头像和昵称(需要自己的服务器)
查看>>
PHP版微信权限验证配置,音频文件下载,FFmpeg转码,上传OSS和删除转存服务器本地文件...
查看>>
教程前言 - 回归宣言
查看>>
PHP 7.1是否支持操作符重载?
查看>>
Vue.js 中v-for和v-if一起使用,来判断select中的option为选中项
查看>>
Java中AES加密解密以及签名校验
查看>>
定义内部类 继承 AsyncTask 来实现异步网络请求
查看>>
VC中怎么读取.txt文件
查看>>
如何清理mac系统垃圾
查看>>
企业中最佳虚拟机软件应用程序—Parallels Deskto
查看>>
Nginx配置文件详细说明
查看>>
怎么用Navicat Premium图标编辑器创建表
查看>>
Spring配置文件(2)配置方式
查看>>
MariaDB/Mysql 批量插入 批量更新
查看>>
ItelliJ IDEA开发工具使用—创建一个web项目
查看>>
solr-4.10.4部署到tomcat6
查看>>
切片键(Shard Keys)
查看>>
淘宝API-类目
查看>>