Python随机数生成模块教程演示如何在Python中生成伪随机数。

1 介绍

1.1 随机数字生成器

随机数生成器(RNG)生成一组在外观上不显示任何可区分模式的值。随机数生成器分为两类:硬件随机数生成器和伪随机数生成器。硬件随机数生成器被认为能产生真正的随机数。伪随机数生成器根据软件算法生成值。它们产生的值看起来是随机的。但这些值是确定性的,如果算法已知,可以重新生成。

在计算中,随机生成器用于游戏、模拟或密码学。为了安全起见,必须使用加密安全的伪随机数生成器。为了提高伪随机数生成器的质量,操作系统使用从设备驱动程序、用户输入延迟或来自一个或多个硬件组件的抖动中收集的环境噪声。这是加密安全伪随机数生成器的核心。

1.2 Python random 模块

内置的Python random模块为各种分布实现伪随机数生成器。Python使用Mersenne Twister算法来生成伪随机数。这个模块安全性不高。对于安全相关的任务,推荐使用secrets模块。

1.3随机种子

种子是初始化随机数生成器的值。随机数生成器通过对以前的值执行一些操作来生成值。当算法开始时,种子是生成器操作的初始值。生成器最重要和最困难的部分是提供接近真正随机数的种子。要注意的是同一种子产生相同的伪随机数集。

2 使用

2.1 Python random模块同一随机种子使用

在下面的示例中,我们使用相同的种子。相同的种子值产生相同的伪随机值。

import random

myseed = 16

# 设置随机种子
random.seed(myseed) # 产生随机数
print(random.random())
print(random.random())
print(random.random()) print('********************************') random.seed(myseed) print(random.random())
print(random.random())
print(random.random())
0.36152277491407514
0.480480665601294
0.4169526266056648
********************************
0.36152277491407514
0.480480665601294
0.4169526266056648

2.2 Python random.randint

random.randint函数在值[x,y]之间生成整数。以下示例生成数字1到10之间的四个随机整数。

import random

val = random.randint(1, 10)
print(val) val = random.randint(1, 10)
print(val) val = random.randint(1, 10)
print(val) val = random.randint(1, 10)
print(val)
5
6
3
10

2.3 Python random.randrange

random.randrange函数排除了右边的区间。它选择[x,y)之间的值。以下示例生成数字1到10之间的四个随机整数,其中排除了值10。

import random

val = random.randrange(1, 10)
print(val) val = random.randrange(1, 10)
print(val) val = random.randrange(1, 10)
print(val) val = random.randrange(1, 10)
print(val)
5
1
4
5

2.4 Python random.uniform

random.uniform函数在值[x,y]之间生成随机浮点数。以下示例在数字1和10之间产生四个随机浮点数。

import random

val = random.uniform(1, 10)
print(val) val = random.uniform(1, 10)
print(val) val = random.uniform(1, 10)
print(val) val = random.uniform(1, 10)
print(val)
1.1833595562120247
2.3856384178156502
6.45443300907888
6.678603948997886

2.5 Python random.choice

该random.choice函数从非空序列返回一个随机元素。该示例从列表中随机抽取一个单词四次。

import random

words = ['sky', 'storm', 'rock', 'falcon', 'forest']

val = random.choice(words)
print(val) val = random.choice(words)
print(val) val = random.choice(words)
print(val) val = random.choice(words)
print(val)
falcon
falcon
forest
rock

2.6 Python random.shuffle

random.shuffle函数可以将序列打乱。以下示例将单词列表随机打乱两次。

import random

words = ['sky', 'storm', 'rock', 'falcon', 'forest']

random.shuffle(words)
print(words) random.shuffle(words)
print(words)
['sky', 'falcon', 'forest', 'rock', 'storm']
['storm', 'forest', 'falcon', 'sky', 'rock']

2.7 Python random.sample

random.sample允许从一个序列中随机抽取n个唯一元素。以下示例从单词列表中两次随机抽取三个元素。

import random

words = ['sky', 'storm', 'rock', 'falcon', 'forest']

sample = random.sample(words, 3)
print(sample) sample = random.sample(words, 3)
print(sample)
['storm', 'rock', 'forest']
['rock', 'falcon', 'storm']

2.8 Python secrets 模块

secrets模块用于生成适合管理密码、帐户身份验证或安全令牌等数据的强随机数。sercets模块中token_hex函数返回一个随机的十六进制文本字符串。token_urlsafe函数返回一个url安全的随机文本字符串。

import secrets
import string # 返回一个随机的十六进制文本字符串
print(secrets.token_hex(12))
# 返回随机文本字符串
print(secrets.token_urlsafe(12)) # 生成一个八个字符的字母数字密码
alphabet = string.ascii_letters + string.digits
password = ''.join(secrets.choice(alphabet) for i in range(8)) print(password)
49a4c25d535581c0e1edaf71
_FHy1al7lB4fyVqU
JjLoiy7k

2.9 Python UUID模块

通用唯一标识符(Universally Unique Identifier)UUID是指一台机器上生成的数字,UUID是128位的全局唯一标志,通常由32字节的字符串表示。UUID由以下几部分组成:

  • 时间戳uuid1():根据时间或时钟序列生成字符串

  • 分布式计算uuid2():根据分布式计算环境DCE生成字符串

  • 机器识别号uuid3():根据MAC地址或者IP生成字符串,没有网卡则通过其他方式生成。

  • 随机数uuid4():自动随机生成一组序列字符串

  • 散列值uuid5(): 基于名字和SAHI值

python中uuid模块提供UUID类,UUID类中通过函数uuid1(), uuid3(), uuid4(), uuid5()来生成1, 3, 4, 5各个版本的UUID ( python中没有uuid2()这个函数,但是UUID标识符中有该指示实现,原因uuid2和uuid1类似,所以uuid2极少使用)。

import uuid

name = "test"

print(uuid.uuid1())
print(uuid.uuid3(uuid.NAMESPACE_DNS, name))
print(uuid.uuid4())
print(uuid.uuid5(uuid.NAMESPACE_DNS, name))
62ecaf30-b61a-11ea-ac5b-0a58ac13091e
45a113ac-c7f2-30b0-90a5-a399ab912716
109e9212-e837-4cd9-9e21-3b48aba373fa
4be0643f-1d98-573b-97cd-ca98a65347dd

uuid1可保证生成全球范围的唯一性字符. 但通过该方法生成的字符中包含有主机的网络地址, 可能危及隐私,根据实验的结果,产生的UUID后面几段的数字会完全一样。uuid4使用随机数来生成UUID但是伪随机数有较低的重复概率。uuid3和uuid5类似,都是通过计算命名空间和名字的SHA-1散列值来生成UUID。

在实际使用uuid1和uuid4较多,uuid3和uuid5更适合唯一性更高的场合。

3 参考

http://zetcode.com/python/random-module/

https://www.jianshu.com/p/f99737713c1b

https://www.cnblogs.com/iamjianghao/p/10764525.html

[编程基础] Python随机数生成模块总结的更多相关文章

  1. [编程基础] Python日志记录库logging总结

    Python日志记录教程展示了如何使用日志记录模块在Python中进行日志记录. 文章目录 1 介绍 1.1 背景 1.2 Python日志记录模块 1.3 根记录器 2 Python logging ...

  2. [编程基础] Python模块和包使用笔记

    本文探讨Python模块和Python包,这两种机制有助于模块化编程. 模块化编程是指将大型笨拙的编程任务分解为单独的,较小的,更易于管理的子任务或模块的过程.然后可以像构建模块一样将各个模块拼凑在一 ...

  3. PythonStudy——编程基础 Python Primary

    1.什么是编程语言 语言:  一个事物与另外一个事物沟通的介质 .编程语言是程序员与计算机沟通的介质. 编程: 将人类内识别的语言转化为机器能识别的指令,这种过程就叫做编程. 注:最终这些指令会被转化 ...

  4. python基础===Python 迭代器模块 itertools 简介

    本文转自:http://python.jobbole.com/85321/ Python提供了一个非常棒的模块用于创建自定义的迭代器,这个模块就是 itertools.itertools 提供的工具相 ...

  5. 【学习笔记】第二章 python安全编程基础---python爬虫基础(urllib)

    一.爬虫基础 1.爬虫概念 网络爬虫(又称为网页蜘蛛),是一种按照一定的规则,自动地抓取万维网信息的程序或脚本.用爬虫最大的好出是批量且自动化得获取和处理信息.对于宏观或微观的情况都可以多一个侧面去了 ...

  6. [编程基础] Python命令行解析库argparse学习笔记

    Python argparse教程展示了如何使用argparse模块解析Python中的命令行参数. 文章目录 1 使用说明 1.1 Python argparse可选参数 1.2 Python ar ...

  7. [编程基础] Python对象的浅拷贝与深拷贝笔记

    Python中的赋值语句不创建对象的副本,它们只将名称绑定到对象.对于不可变的对象,这通常没有什么区别.但是对于处理可变对象或可变对象的集合,您可能需要寻找一种方法来创建这些对象的"真实副本 ...

  8. [编程基础] Python中的绝对导入与相对导入

    如果您从事的Python项目有多个文件,那么您以前可能不得不使用import语句.即使对于拥有多个项目的Python重度使用者(比如我),import也可能会造成混淆!您可能正在阅读本文,因为您想对P ...

  9. [编程基础] Python字符串替换笔记

    Python字符串替换笔记 Python字符串替换笔记主要展示了如何在Python中替换字符串.Python中有以下几种替换字符串的方法,本文主要介绍前三种. replace方法(常用) transl ...

随机推荐

  1. Jquery关于checkbox选中第二次失效的问题。

    $(".selector input[type='checkbox']").attr("checked",true); $(".selector in ...

  2. 我说HashMap初始容量是16,面试官让我回去等通知

    众所周知HashMap是工作和面试中最常遇到的数据类型,但很多人对HashMap的知识止步于会用的程度,对它的底层实现原理一知半解,了解过很多HashMap的知识点,却都是散乱不成体系,今天一灯带你一 ...

  3. maven 重复依赖不同版本 选择规则

    maven 重复依赖不同版本 选择规则 本篇主要来看看 maven 对于 重复依赖的jar的不同版本时候 它内部的选择规则, 很多时候我们在搭建环境的时候 不注意就会存在依赖冲突等问题 那依赖冲突的时 ...

  4. Codeforces 1670 E. Hemose on the Tree

    题意 给你个数p,n = 2^p: 有一棵树有n个节点,告诉你怎么连边: 每个点有个权值,每条边也有个权值,权值需要自行分配,[1,2,3..n...2n-1],总共2n-1个权值: 你需要选一个节点 ...

  5. cordon节点,drain驱逐节点,delete 节点

    目录 一.系统环境 二.前言 三.cordon节点 3.1 cordon节点概览 3.2 cordon节点 3.3 uncordon节点 四.drain节点 4.1 drain节点概览 4.2 dra ...

  6. 扫雷(哈希+bfs)

    扫雷 题目描述: 小明最近迷上了一款名为<扫雷>的游戏. 其中有一个关卡的任务如下: 在一个二维平面上放置着 n 个炸雷,第 i 个炸雷 (x\(_i\),y\(_i\),r\(_i\)) ...

  7. Codeforces Round #811 (Div. 3)D. Color with Occurrences

    题目大意:给出一个文章t和n个字符串s1,s2...sn: 问能否用这n个字符串将整个文章覆盖: 思路:贪心(最小区间覆盖) 记录每个字符串能够覆盖的所有位置(起点,终点,编号) 排序后贪心的求出是否 ...

  8. 2022春每日一题:Day 11

    题目:高斯消元法 高斯消元法是一个模板,下面简单介绍其内容以及实现方法. 高斯消元是求一个求多元一次方程组的解的算法. 就是形式如下的关于x1,x2...xn的方程组的解. a11x1 + a12x2 ...

  9. codeforces补题计划

    11.15 Codeforces Round #833 (Div. 2) 知识点: D:高位和对低位无影响 E:笛卡尔树上dp 补题传送门

  10. rpm环境安装dpkg包管理工具

    rpm环境安装dpkg包管理工具 索引:dpkg-scanpackages.dpkg.dpkg-query.dpkg-source.dpkg-scansource 在centos.redhat.麒麟服 ...