百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

python散装笔记—55: Random 模块

wptr33 2025-02-27 16:55 14 浏览

1: 随机创建用户密码

为了创建随机用户密码,我们可以使用 string 模块中提供的符号。具体来说,标点符号使用 punctuation,字母使用 ascii_letters,数字使用 digits

from string import punctuation, ascii_letters, digits

然后,我们可以将所有这些符号组合在一个名为 symbols 的名称中:

symbols = ascii_letters + digits + punctuation

移除其中任何一个,以创建一个元素较少的符号库。

然后,我们可以使用 random.SystemRandom 生成密码。对于长度为 10 的密码

>>> secure_random = random.SystemRandom()
>>> password = "".join(secure_random.choice(symbols) for i in range(10))
>>> print(password) # '^@g;J?]M6e'

请注意,由 random 模块提供的其他例程,如 random.choicerandom.randint等,不适合用于加密目的。

在后台,这些例程使用的是Mersenne Twister PRNG,它不符合CSPRNG的要求。因此,你谨记不应该使用它们中的任何一个来生成你计划使用的密码。请始终使用如上所示的 SystemRandom 实例。

Python 3.x Version ≥ 3.6

从 Python 3.6 开始,secrets 模块可用,它提供了加密安全功能。

引用 官方文档,要生成 "一个至少有一个小写字母、至少有一个大写字母、至少有三位数字的十字符字母数字密码",可以这样做

import string
alphabet = string.ascii_letters + string.digits
while True:
  password = ''.join(choice(alphabet) for i in range(10))
  if (any(c.islower() for c in password) 
      and any(c.isupper() for c in password) 
      and sum(c.isdigit() for c in password) >= 3):
    break

2: 创建加密安全随机数

Python 随机模块默认使用 Mersenne Twister PRNG来生成随机数,这虽然适用于模拟等领域,但在要求更高的环境中却无法满足安全要求。

为了创建加密安全的伪随机数,可以使用SystemRandom,通过使用os.urandom,它可以充当加密安全的伪随机数生成器CPRNG。

最简单的使用方法是初始化 SystemRandom 类。它提供的方法与 random 模块导出的方法类似。

from random import SystemRandom
secure_rand_gen = SystemRandom()

要创建范围 [0, 20] 内 10 个 int 的随机序列,只需调用 randrange() 即可:

print([secure_rand_gen.randrange(10) for i in range(10)])
# [9, 6, 9, 2, 2, 3, 8, 0, 9, 9]

要在给定范围内创建一个随机整数,可以使用 randint

print(secure_rand_gen.randint(0, 20))
# 5

以及所有其他方法。接口完全相同,唯一的变化是底层的数字生成器。

你也可以直接使用 os.urandom 来获取加密安全的随机字节。

3: 随机和序列:洗牌、选择和抽样

import random

shuffle()

您可以使用 random.shuffle() 来混合/随机化可变和可索引序列中的项目。例如一个 list

laughs = ["Hi", "Ho", "He"]

random.shuffle(laughs) # Shuffles in-place! Don't do: laughs = random.shuffle(laughs)

print(laughs)
# Out: ["He", "Hi", "Ho"] # Output may vary!

choice()

从任意序列中随机抽取一个元素:

print(random.choice(laughs))
# Out: He # Output may vary!

sample()

choice 类似,它从任意序列中随机抽取元素,但可以指定多少个:

# |--sequence--|--number--|
print(random.sample( laughs , 1 )) # Take one element
# Out: ['Ho'] # Output may vary!

不会重复使用相同的元素:

print(random.sample(laughs, 3)) # Take 3 random element from the sequence.
# Out: ['Ho', 'He', 'Hi'] # Output may vary!
print(random.sample(laughs, 4)) # Take 4 random element from the 3-item sequence.
# ValueError: Sample larger than population

4: 创建随机整数和浮点数:randint、randrange、random 和 uniform

import random

randint()

返回介于 x 和 y 之间的随机整数:

random.randint(x, y)

例如,在 1 到 8 之间随机获取一个数字:

random.randint(1, 8) # Out: 8

randrange()

random.randrange 的语法与 range 相同,但与 random.randint 不同的是,最后一个值不包含在内:

random.randrange(100) # Random integer between 0 and 99
random.randrange(20, 50) # Random integer between 20 and 49
random.randrange(10, 20, 3) # Random integer between 10 and 19 with step 3 (10, 13, 16 and 19)

random

返回一个介于 0 和 1 之间的随机浮点数:

random.random() # Out: 0.66486093215306317

uniform

返回介于 x 和 y 之间的随机浮点数:

random.uniform(1, 8) # Out: 3.726062641730108

5: 可重复的随机数: 种子和状态

设置特定的 seed 将创建一个固定的随机数系列:

random.seed(5) # Create a fixed state
print(random.randrange(0, 10)) # Get a random integer between 0 and 9
# Out: 9
print(random.randrange(0, 10))
# Out: 4

重置种子将再次创建相同的 "random" 序列:

random.seed(5) # Reset the random module to the same fixed state.
print(random.randrange(0, 10))
# Out: 9
print(random.randrange(0, 10))
# Out: 4

由于种子是固定的,因此结果总是 9 和 4。如果不需要特定的数字,只要求数值相同,也可以使用 getstatesetstate 恢复到之前的状态:

save_state = random.getstate() # Get the current state
print(random.randrange(0, 10))
# Out: 8
print(random.randrange(0, 10))
# Out: 0

random.setstate(save_state) # Reset to saved state
print(random.randrange(0, 10))
# Out: 8
print(random.randrange(0, 10))
# Out: 0

要再次对序列进行伪随机化,需要使用 None 作为种子:

random.seed(None)

或者调用不带参数的种子方法:

random.seed()

6: 随机二进制决策

import random

probability = 0.3

if random.random() < probability:
  print("Decision with probability 0.3")
else:
  print("Decision with probability 0.7")

相关推荐

redis的八种使用场景

前言:redis是我们工作开发中,经常要打交道的,下面对redis的使用场景做总结介绍也是对redis举报的功能做梳理。缓存Redis最常见的用途是作为缓存,用于加速应用程序的响应速度。...

基于Redis的3种分布式ID生成策略

在分布式系统设计中,全局唯一ID是一个基础而关键的组件。随着业务规模扩大和系统架构向微服务演进,传统的单机自增ID已无法满足需求。高并发、高可用的分布式ID生成方案成为构建可靠分布式系统的必要条件。R...

基于OpenWrt系统路由器的模式切换与网页设计

摘要:目前商用WiFi路由器已应用到多个领域,商家通过给用户提供一个稳定免费WiFi热点达到吸引客户、提升服务的目标。传统路由器自带的Luci界面提供了工厂模式的Web界面,用户可通过该界面配置路...

这篇文章教你看明白 nginx-ingress 控制器

主机nginx一般nginx做主机反向代理(网关)有以下配置...

如何用redis实现注册中心

一句话总结使用Redis实现注册中心:服务注册...

爱可可老师24小时热门分享(2020.5.10)

No1.看自己以前写的代码是种什么体验?No2.DooM-chip!国外网友SylvainLefebvre自制的无CPU、无操作码、无指令计数器...No3.我认为CS学位可以更好,如...

Apportable:拯救程序员,IOS一秒变安卓

摘要:还在为了跨平台使用cocos2d-x吗,拯救objc程序员的奇葩来了,ApportableSDK:FreeAndroidsupportforcocos2d-iPhone。App...

JAVA实现超买超卖方案汇总,那个最适合你,一篇文章彻底讲透

以下是几种Java实现超买超卖问题的核心解决方案及代码示例,针对高并发场景下的库存扣减问题:方案一:Redis原子操作+Lua脚本(推荐)//使用Redis+Lua保证原子性publicbo...

3月26日更新 快速施法自动施法可独立设置

2016年3月26日DOTA2有一个79.6MB的更新主要是针对自动施法和快速施法的调整本来内容不多不少朋友都有自动施法和快速施法的困扰英文更新日志一些视觉BUG修复就不翻译了主要翻译自动施...

Redis 是如何提供服务的

在刚刚接触Redis的时候,最想要知道的是一个’setnameJhon’命令到达Redis服务器的时候,它是如何返回’OK’的?里面命令处理的流程如何,具体细节怎么样?你一定有问过自己...

lua _G、_VERSION使用

到这里我们已经把lua基础库中的函数介绍完了,除了函数外基础库中还有两个常量,一个是_G,另一个是_VERSION。_G是基础库本身,指向自己,这个变量很有意思,可以无限引用自己,最后得到的还是自己,...

China&#39;s top diplomat to chair third China-Pacific Island countries foreign ministers&#39; meeting

BEIJING,May21(Xinhua)--ChineseForeignMinisterWangYi,alsoamemberofthePoliticalBureau...

移动工作交流工具Lua推出Insights数据分析产品

Lua是一个适用于各种职业人士的移动交流平台,它在今天推出了一项叫做Insights的全新功能。Insights是一个数据平台,客户可以在上面实时看到员工之间的交流情况,并分析这些情况对公司发展的影响...

Redis 7新武器:用Redis Stack实现向量搜索的极限压测

当传统关系型数据库还在为向量相似度搜索的性能挣扎时,Redis7的RedisStack...

Nginx/OpenResty详解,Nginx Lua编程,重定向与内部子请求

重定向与内部子请求Nginx的rewrite指令不仅可以在Nginx内部的server、location之间进行跳转,还可以进行外部链接的重定向。通过ngx_lua模块的Lua函数除了能实现Nginx...