更新时间:2019.09.12(更新目录)

目录
1. 谈谈随机数
2. random模块
  2.1 random.seed()
  2.2 random.random()
  2.3 random.randrange()
  2.4 random.randint()
  2.5 random.uniform()
  2.6 random.sample()
  2.7 random.choice()
  2.8 random.choices()
  2.9 random.shuffle()
3. 其他补充资料

1. 谈谈随机数:

  我们经常会用到随机数,对它也并不陌生。但是谈到如何使用计算机来生成随机数的时候,我们便会发现,无论是多么先进的计算机都难以实现真正意义上完全随机的数。实际上,我们使用计算机生成的都是伪随机数。虽说是“伪”随机数,但也不能说它是假的随机数,而是应该归为有一定规律的随机数

  那为什么说这些计算机生成的数是“有规律”的呢?主要是这些随机数都是通过随机数种子来迭代计算生成的,通常来说这些随机数种子来自于当前系统的时间戳或者操作系统中的随机源。并且由于每台计算机的硬件层面都有所不同,所以用不同计算机生成的随机数基本都是不同的(系统时间是通过计算机主板的定时计数器来计算的)。

  如果我们固定随机数种子后,每次在同一台计算机得到的随机数都是一样的。而对于默认由系统时间戳得到的随机数种子,在短时间内生成大量随机数时也会出现不少重复。因此,如果我们想生成接近于真正意义上的随机上,就需要对随机数种子设置更多的参考指标。

2. Random模块---用于生成各种分布的伪随机数

2.1 random.seed(a=None, version=2):
  • 作用:设置随机数种子,
  • 参数:第一个如果不指定就默认是当前的系统时间戳或者操作系统中提供的随机源,第二个参数是指所使用的种子版本(version),默认是版本2,可以将str、byte、bytearay等对象转为int并使用所有位。而版本1(旧)是用于str和byte生成更窄的种子范围。
  • 例子:
2.2 random.random():
  • 作用:获取区间[0, 1)的一个浮点随机数
  • 参数:不需要参数
  • 例子:
2.3 random.randrange(start, stop[, step]):(其实就好像range一样
  • 作用:在指定的范围里,随机抽取一个整数
  • 参数:接收的都是整数,第一个是start,第二个是stop,第三个是步长step(可选)
  • 例:
2.4 random.randint(a, b):
  • 作用:从[a, b]中生成一个随机整数,等价于random.randrange(a, b+1)
  • 参数:a表示起始范围,b表示终止范围
  • 例:
2.5 random.uniform(a, b):
  • 作用:获取区间[a, b)或者[a, b]的一个浮点随机数
  • 参数:如果a > b, 则获取的随机数是b<=N<=a,如果a < b, 则获取的随机数是a<=N<=b
  • tip:由于它是根据a+(b-a)*random.random(),并对结果进行舍入,所以可能包含边界b也可能不包含b
  • 例:
2.6 random.sample(seq, k):
  • 作用:用于样本抽样
  • 参数:第一个是序列或者集合(像当总体较大时指定range()作为参数,即快又节省内存),第二个是用于指定选取几个样本,最后返回样本列表
  • tip1:从总体序列或者集合中不放回地选取n个样本,其中样本数不能大于总体序列的长度
  • tip2:如果序列中有包含重复的元素,这些元素都有机会入样
  • 例:
2.7 random.choice(seq):
  • 作用:从一个非空的序列中随机选择一个元素
  • 参数:非空序列
  • 例:
2.8 random.choices(seq, weights=None, *, cum_weights=None, k=1):
  • 作用:可以对序列的元素给定权重(权重的个数要和序列的长度相同),并且选取多个元素,不给定时默认各个元素的权重是相等的
  • 参数:第一个序列,第二三个是权重(可选),第四个是选择个数,最后返回的是一个列表
  • tip1:权重的形式可以是相对权重weights(像[10,30,40,20])或者累计权重cum_weights(像[10, 40, 80, 100])。但实际上在执行时,相对权重会转化为累计权重,因此直接使用累计权重可以节省工作量
  • tip2:权重可以指定任何的数字形式(整数、浮点数、分数等)
  • 例:
2.9 random.shuffle(seq):
  • 作用:将可变序列元素的位置打乱
  • 参数:要打乱位置的序列
  • tip:如果想将不可变序列(像元组、字符串等)的元素位置打乱,可以使用random.sample(x, len(x))
  • 例:

3. 其他补充资料:

实际上有许多中方法来计算随机数,像Python就是用梅森旋转法来计算的。

Python标准库---random模块的使用的更多相关文章

  1. [python标准库]Pickle模块

    Pickle-------python对象序列化 本文主要阐述以下几点: 1.pickle模块简介 2.pickle模块提供的方法 3.注意事项 4.实例解析 1.pickle模块简介 The pic ...

  2. Python 标准库 ConfigParser 模块 的使用

    Python 标准库 ConfigParser 模块 的使用 demo #!/usr/bin/env python # coding=utf-8 import ConfigParser import ...

  3. Python标准库——collections模块的Counter类

    1.collections模块 collections模块自Python 2.4版本开始被引入,包含了dict.set.list.tuple以外的一些特殊的容器类型,分别是: OrderedDict类 ...

  4. [python标准库]XML模块

    1.什么是XML XML是可扩展标记语言(Extensible Markup Language)的缩写,其中的 标记(markup)是关键部分.您可以创建内容,然后使用限定标记标记它,从而使每个单词. ...

  5. 【python】Python标准库defaultdict模块

    来源:http://www.ynpxrz.com/n1031711c2023.aspx Python标准库中collections对集合类型的数据结构进行了很多拓展操作,这些操作在我们使用集合的时候会 ...

  6. python标准库 bisect模块

    # -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' #bisect #作用:维护有序列表,而不必在每次向列表增加一个元素 ...

  7. Python标准库--os模块

    这个模块包含普遍的操作系统功能.如果你希望你的程序能够与平台无关的话,这个模块是尤为重要的.即它允许一个程序在编写后不需要任何改动,也不会发生任何问题,就可以在Linux和Windows下运行.一个例 ...

  8. Python标准库Random

    基本方法 获取一个[0,1)的随机浮点数: import random print(random.random()) #输出 0.6701488343121276 获取指定区间的随机浮点数: impo ...

  9. python标准库 sysconfig模块

    # -*- coding: utf-8 -*-# python:2.x__author__ = 'Administrator'import sysconfig#sysconfig:解释器编译时配置#作 ...

随机推荐

  1. selenium-03-02操作元素-等待

    1.最直接普通的方式:这个是设置固定的等待时间    Thread.sleep(1000);   2.隐式等待方式(implicitlyWait):设置脚本在查找元素时的最大等待时间:    driv ...

  2. SpringCloud搭建注册中心与服务注册

    上一篇文章<微服务注册中心原理,看这篇就够了!>介绍了注册中心的概念和原理,本文将介绍下利用Eureka搭建中心并注册服务到注册中心的过程. 本文目录 一.Eureka介绍二.搭建注册中心 ...

  3. CDH 5.9.3 集群配置

    -----------------------------------------集群规划------------------------------------------ hostname ip ...

  4. 平行世界中的你还是你吗?--java中的==是否相等

    故事背景 <宇宙追缉令>是黄毅瑜执导的动作科幻类电影,由哥伦比亚三星公司出品,戴尔里·林多.李连杰.杰森·斯坦森领衔主演.影片于2001年11月2日在美国上映.该片讲述了邪恶尤兰,为了成为 ...

  5. hadoop入门之海量Web日志分析 用Hadoop提取KPI统计指标

    转载自:http://blog.fens.me/hadoop-mapreduce-log-kpi/ 今天学习了这一篇博客,写得十分好,照着这篇博客敲了一遍. 发现几个问题, 一是这篇博客中采用的had ...

  6. 短视频处理LanSoEditor-SDK之功能介绍

    短视频处理LanSoEditor-SDK之功能介绍  (注释: 我们的SDK每3周更新一次, 一下功能是在2.8.2版本上列出的,可能不是最新的功能, 请知悉) 和别家最大的不同在于: 别人提供功能, ...

  7. .Net Core 商城微服务项目系列(六):搭建自己的Nuget包服务器

    当我们使用微服务架构之后,紧接而来的问题便是服务之间的程序集引用问题,可能没接触过的同学不太理解这句话,都已经微服务化了为什么还要互相引用程序集,当然可以不引用.但是我们会有这样一种情况,我们的每个接 ...

  8. spring源码分析系列3:BeanFactory核心容器的研究

    目录 @(spring源码分析系列3:核心容器的研究) 在讲容器之前,再明确一下知识点. BeanDefinition是Bean在容器的描述.BeanDefinition与Bean不是一个东西. Be ...

  9. springcloud --- spring cloud sleuth和zipkin日志管理(spring boot 2.18)

    前言 在spring cloud分布式架构中,系统被拆分成了许多个服务单元,业务复杂性提高.如果出现了异常情况,很难定位到错误位置,所以需要实现分布式链路追踪,跟进一个请求有哪些服务参与,参与的顺序如 ...

  10. mysql库复制

    一.使用navicate复制mysql库 二.使用命令 通过命令:1.创建新数据库CREATE DATABASE `newdb` DEFAULT CHARACTER SET UTF8 COLLATE ...