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

python散装笔记—55: Random 模块

ztj100 2025-03-04 16:00 14 浏览 0 评论

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")

相关推荐

其实TensorFlow真的很水无非就这30篇熬夜练

好的!以下是TensorFlow需要掌握的核心内容,用列表形式呈现,简洁清晰(含表情符号,<300字):1.基础概念与环境TensorFlow架构(计算图、会话->EagerE...

交叉验证和超参数调整:如何优化你的机器学习模型

准确预测Fitbit的睡眠得分在本文的前两部分中,我获取了Fitbit的睡眠数据并对其进行预处理,将这些数据分为训练集、验证集和测试集,除此之外,我还训练了三种不同的机器学习模型并比较了它们的性能。在...

机器学习交叉验证全指南:原理、类型与实战技巧

机器学习模型常常需要大量数据,但它们如何与实时新数据协同工作也同样关键。交叉验证是一种通过将数据集分成若干部分、在部分数据上训练模型、在其余数据上测试模型的方法,用来检验模型的表现。这有助于发现过拟合...

深度学习中的类别激活热图可视化

作者:ValentinaAlto编译:ronghuaiyang导读使用Keras实现图像分类中的激活热图的可视化,帮助更有针对性...

超强,必会的机器学习评估指标

大侠幸会,在下全网同名[算法金]0基础转AI上岸,多个算法赛Top[日更万日,让更多人享受智能乐趣]构建机器学习模型的关键步骤是检查其性能,这是通过使用验证指标来完成的。选择正确的验证指...

机器学习入门教程-第六课:监督学习与非监督学习

1.回顾与引入上节课我们谈到了机器学习的一些实战技巧,比如如何处理数据、选择模型以及调整参数。今天,我们将更深入地探讨机器学习的两大类:监督学习和非监督学习。2.监督学习监督学习就像是有老师的教学...

Python教程(三十八):机器学习基础

...

Python 模型部署不用愁!容器化实战,5 分钟搞定环境配置

你是不是也遇到过这种糟心事:花了好几天训练出的Python模型,在自己电脑上跑得顺顺当当,一放到服务器就各种报错。要么是Python版本不对,要么是依赖库冲突,折腾半天还是用不了。别再喊“我...

超全面讲透一个算法模型,高斯核!!

...

神经网络与传统统计方法的简单对比

传统的统计方法如...

AI 基础知识从0.1到0.2——用“房价预测”入门机器学习全流程

...

自回归滞后模型进行多变量时间序列预测

下图显示了关于不同类型葡萄酒销量的月度多元时间序列。每种葡萄酒类型都是时间序列中的一个变量。假设要预测其中一个变量。比如,sparklingwine。如何建立一个模型来进行预测呢?一种常见的方...

苹果AI策略:慢哲学——科技行业的“长期主义”试金石

苹果AI策略的深度原创分析,结合技术伦理、商业逻辑与行业博弈,揭示其“慢哲学”背后的战略智慧:一、反常之举:AI狂潮中的“逆行者”当科技巨头深陷AI军备竞赛,苹果的克制显得格格不入:功能延期:App...

时间序列预测全攻略,6大模型代码实操

如果你对数据分析感兴趣,希望学习更多的方法论,希望听听经验分享,欢迎移步宝藏公众号...

AI 基础知识从 0.4 到 0.5—— 计算机视觉之光 CNN

...

取消回复欢迎 发表评论: