惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

P
Privacy International News Feed
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
Jina AI
Jina AI
T
Tailwind CSS Blog
WordPress大学
WordPress大学
Scott Helme
Scott Helme
C
Cybersecurity and Infrastructure Security Agency CISA
博客园 - Franky
C
CERT Recently Published Vulnerability Notes
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
雷峰网
雷峰网
Schneier on Security
Schneier on Security
博客园 - 聂微东
T
Tor Project blog
Hugging Face - Blog
Hugging Face - Blog
博客园 - 司徒正美
AI
AI
T
Troy Hunt's Blog
Security Latest
Security Latest
T
The Blog of Author Tim Ferriss
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
C
Check Point Blog
T
Threat Research - Cisco Blogs
W
WeLiveSecurity
V
Vulnerabilities – Threatpost
Recorded Future
Recorded Future
Recent Commits to openclaw:main
Recent Commits to openclaw:main
Cisco Talos Blog
Cisco Talos Blog
C
CXSECURITY Database RSS Feed - CXSecurity.com
Cloudbric
Cloudbric
J
Java Code Geeks
罗磊的独立博客
C
Cyber Attacks, Cyber Crime and Cyber Security
aimingoo的专栏
aimingoo的专栏
L
LangChain Blog
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
P
Privacy & Cybersecurity Law Blog
Google DeepMind News
Google DeepMind News
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
L
Lohrmann on Cybersecurity
I
InfoQ
MongoDB | Blog
MongoDB | Blog
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
The GitHub Blog
The GitHub Blog
The Hacker News
The Hacker News
H
Help Net Security
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
P
Proofpoint News Feed
N
News and Events Feed by Topic

暗无天日

读:AI Agent 安全日志——从可见性与隐私的两难说起 - 暗无天日 AI写作的语言指纹——如何让文字不那么像机器 - 暗无天日 读:50 条 Claude Code 技巧——一个工程经理的六个月使用心得 读:AI 辅助开发为什么让 E2E 测试更有价值 - 暗无天日 读:在Emacs中使用Claude Code(Spacemacs适配版) - 暗无天日 Claude Code 背后的工程哲学——读 Agent Harness Engineering 读:Agent Harness Engineering——AI 智能体不只是模型,还有套件 - 暗无天日 browser-harness:让 AI 直接接管你的浏览器 - 暗无天日 读:Security-First CI/CD —— DevSecOps 自动化实践指南 TIL: 数字小键盘的小数点陷阱与行内算术求值 - 暗无天日 读:Immutability 不是万能药,它是一种权衡 - 暗无天日 Conducty:给 Claude Code 加上项目记忆和并行执行能力 - 暗无天日 读 — GitHub Trending 里的 Claude Code 技能包 读 — Prompt Caching 省钱指南 TIL: Emacs 中那些跟鼠标配合的冷门快捷键 - 暗无天日 读:Anvil——把 Emacs 变成 AI 的工具服务器 读:Emacs 代码折叠终极指南 - 暗无天日 读:Clojure 搭车客指南 - 暗无天日 git推送失败后恢复仓库损坏的完整记录 - 暗无天日 多智能体系统的两个有效模式——以及对 Claude Code 用户的启示 - 暗无天日 用 Org Babel 写 Literate 博文:扩展执行 + 定制导出 proced:Emacs 内置的进程查看器 - 暗无天日 从 proced 定制中学到的 Elisp 模式 读:让 Emacs proced 在 macOS 上显示 CPU 和内存 异步编程的函数着色税 - 暗无天日 链式调用的代价:JavaScript 和 Clojure 的共同教训 - 暗无天日 hyperfine:命令行基准测试工具 - 暗无天日 管道中的变量去哪了?——子 shell 作用域陷阱 - 暗无天日 开源包装器的信任陷阱:四个危险信号 - 暗无天日 程序员愿意为 AI 写文档,却不愿为同事写 - 暗无天日 mktemp: Shell 脚本中临时文件的安全陷阱与最佳实践 - 暗无天日 WSL9x —— 在 Windows 9x 里跑 Linux 内核 6.19 用 ox.el 做你想做的事 —— org-export 高级编程指南 读:Hot-wiring the Lisp Machine —— 用纯 Elisp 构建零依赖的 Org 静态站点生成器 Elisp 性能优化的六个实战教训 - 暗无天日 fcitx5 下 Emacs 无法切换输入法的排查 - 暗无天日 ERT 测试交互命令的三种方式 - 暗无天日 SEM Assistant: 当 Elisp 守护进程遇上 LLM 用 dmsg 给 Elisp 加上结构化调试日志 用 org-habit 追踪非每日习惯 - 暗无天日 Clojure X-Men:当编程语言特性变成超能力 - 暗无天日 TIL: 用 diff-hl 在 fringe 中显示 git 变更 读:llm-test —— 用 LLM agent 驱动 Emacs 测试 TIL: AI 时代的橡皮鸭调试 - 暗无天日 fcitx 启动后键盘输入卡顿的排查 - 暗无天日 TIL: 早期网页的图片热区导航 - 暗无天日 读 Seeing the Whole System 用 Emacs 自动生成每周链接推荐 - 暗无天日 读:ASCII control characters in my terminal 读 What to learn - 暗无天日 Lisp 的括号之痛——一个愚人节玩笑揭开的老伤疤 - 暗无天日 一本书该"线性读"还是"并行读" - 暗无天日 读 How to Monetize a Blog:一篇伪装成变现指南的讽刺文 Python Mock 第三方依赖的四种策略 - 暗无天日 Emacs Lisp 热重载实用指南 - 暗无天日 Prot 的 Emacs 配置哲学 - 暗无天日 TIL: 从直播对谈中学到的三个 Emacs 技巧 - 暗无天日 TIL: 自动使用项目虚拟环境的 Python - 暗无天日 TIL: 让 Help buffer 自动获得焦点 一条命令让本地开发用上 HTTPS —— slim 工具介绍 用 fsck 检查和修复 Linux 文件系统 排查Linux进程"卡死"实战:从strace到gdb全流程 - 暗无天日 PostgreSQL 索引:从基础到你可能不知道的高级用法 - 暗无天日 用 .pdbrc 自定义 Python 调试器 ANSI 转义码的标准化现状 - 暗无天日 终端程序的潜规则 - 暗无天日 PARA Org-mode 测试配置 - 暗无天日 AI越强越辣鸡?控制论说这是必然的 - 暗无天日 AI 越强越需要你盯着——反馈循环实操指南 - 暗无天日 你的AI代理正在偷你的密钥——四种你没想到的泄露通道 - 暗无天日 LLM 在 DevOps 中的三种角色 - 暗无天日 写作风格的反建议 - 暗无天日 反驳本质复杂性——Dan Luu 论为什么《没有银弹》错了 - 暗无天日 文件充满了危险——Dan Luu 谈文件系统的可靠性陷阱 - 暗无天日 AI 时代的 PARA 方法:用 Org-mode 和 AI 打造个人知识管理系统 Linux 数据去重学习笔记 - 暗无天日 创建跨平台 ZIP 文件的隐藏陷阱:Extra Field - 暗无天日 X11 Forwarding 排障指南 - 暗无天日 IP欺骗端口扫描:当别人冒充你去扫描别人 - 暗无天日 Linux 输入栈全景解析:从硬件按键到屏幕响应 - 暗无天日 Unix 系统中那些被埋没的配置开关——以 FontConfig 为例 - 暗无天日 在Linux上限制儿童使用电脑 - 暗无天日 GIF不仅仅是一种图片格式——用GIF流做些奇怪的事 - 暗无天日 Leiningen 学习笔记:Clojure 项目构建与管理从入门到实战配置 - 暗无天日 Google SRE Book 读书笔记 - 暗无天日 yes 管道 head 发生了什么 - 暗无天日 为什么 nohup 在 crontab 中不起作用 Bash中的Indirection与Nameref - 暗无天日 Linux PAM 简介 - 暗无天日 从Linux ISO文件启动计算机 - 暗无天日 用 Bash 打造一个Screen Locker 用GitHub Actions自动构建EGO博客 - 暗无天日 blocking I/O 的作用 - 暗无天日 mobileog 手机端同步提示Error:2 No such file 的解决方法 回收 WSL2 VHDX 文件占用空间 使用 org-mode columnview 生成任务列表 - 暗无天日 Emacs 作为 MPD 客户端 - 暗无天日 移动文件路径却不破坏org file link的方法 - 暗无天日 如何合理的导出help link 成HTML - 暗无天日 笑话理解之Biology - 暗无天日
读:Python 随机数生成——从 random 到 secrets
lujun9972,Claude Code · 2026-05-31 · via 暗无天日

目录

  • 随机整数, randintrandrange
  • 随机浮点数, random
  • 从序列中随机选择, choicechoices
  • 伪随机数的可复现性
  • 密码学安全的随机数, secrets 模块
  • SystemRandom 类
  • 总结,什么场景用什么

本文是对 Python Morsels: Random Numbers 一文的解读和整理。

Python 标准库里跟随机数打交道的模块有两个, randomsecretsrandom 生成伪随机数,速度快,日常用够了。 secrets 生成密码学安全的随机数,不可预测,安全相关的场景用这个。

先看最常用的几个操作。

随机整数, randintrandrange

最常用的随机整数函数是 randint 。它接受起始值和结束值,返回两者之间的随机整数, 包含两端

from random import randint
print(randint(1, 6))
3

random 模块还有个 randrange 函数,命名和用法都跟内置的 range 函数一致。 range 能怎么调, randrange 就能怎么调。

只传终止值(从 0 到终止值之间,不包含终止值):

from random import randrange
print(randrange(10))
2
2

传起始值和终止值:

8

传起始值、终止值和步长:

print(randrange(0, 100, 10))
90

randintrandrange 的区别在于对终止值的处理。 randint(1, 6) 可能返回 6, randrange(6) 永远不会返回 6。需要随机整数时, randint 更直观。

随机浮点数, random

想要随机浮点数的话,用 random 函数。它返回 0.0 到 1.0 之间的浮点数:

from random import random
print(random())
0.3452380767261871

乘以一个倍数就能得到更大范围的值:

23.577339429778577

不过实际编程中,随机浮点数的需求远不如随机整数频繁。大多数时候你要的是从列表里挑一个或者掷骰子,用整数或后面要说的 choice 就够了。

从序列中随机选择, choicechoices

很多时候你要的不是一个随机数,是从一组东西里随机挑一个。这种场合 random.choicerandint 更直接。

假设有一个颜色列表,想随机挑一种颜色:

from random import choice
colors = ["red", "blue", "green", "yellow", "purple"]
print(choice(colors))
purple

如果你需要挑多个(允许重复),用 choices 并指定 k 参数:

from random import choices
colors = ["red", "blue", "green", "yellow", "purple"]
print(choices(colors, k=3))
['green', 'yellow', 'green']

choicechoices 适用于任何序列类型,不只是列表。字符串也是序列,所以可以直接从字符集合里挑:

from random import choices
print(choices("ACGT", k=10))
['T', 'T', 'C', 'C', 'G', 'G', 'A', 'C', 'G', 'T']

这个特性在生成随机字符串时特别有用——普通场景(比如 DNA 序列模拟)用 random.choices 就够了,安全敏感的场景(验证码、令牌)则要用后面会说的 secrets.choice

伪随机数的可复现性

random 模块生成的是伪随机数。底层用的是梅森旋转算法(Mersenne Twister),一个确定性算法。只要初始状态相同,产生的随机序列就完全相同。

所以你可以通过设置随机种子(seed)让随机数变得 可预测 。听起来跟「随机」矛盾,但在测试和调试时特别好用。拿下面这个 generate_code 函数来说,它能生成 16 位随机字符串:

import random

def generate_code():
    characters = "ABCDEFGHJKLPQRTUVWXY234679"
    return "".join([random.choice(characters) for _ in range(16)])

random.seed(5)
print(generate_code())
YJ6P9462VAT7H2BF

每次用 random.seed(5) 设定种子后,第一次调用 generate_code() 的结果永远是 YJ6P9462VAT7H2BF ,跟在哪台机器上跑都无关。这样写测试就靠得住:

random.seed(5)
assert generate_code() == "YJ6P9462VAT7H2BF"
print("Test passed")
Test passed

而且种子可以重复设置,相同的种子会产生相同的随机序列:

from random import seed, randint

seed(42)
print(randint(1, 100))
seed(42)
print(randint(1, 100))
82
82

可复现性在调试时很有用,某个随机数触发的 bug,只要记住种子就能反复复现。但这可预测性也有坏处。Python 的默认种子基于当前时间,如果有人能猜出你的代码什么时候跑的,或者从你生成的几个随机数反推出种子的状态,他就能预测你接下来会生成什么。如果你的随机数涉及密码、令牌、session key 这些安全敏感场景,就别用 random 了。

密码学安全的随机数, secrets 模块

需要生成第三方不可预测的随机数时,用 secrets 模块。它从操作系统的安全随机源(比如 Linux 的 /dev/urandom )读取数据,生成的随机数在密码学意义上是安全的,不可预测。

secrets 也提供了 choice 函数,用法跟 random.choice 一样,结果是不可预测的。

import secrets

characters = "ABCDEFGHJKLPQRTUVWXY234679"
print(secrets.choice(characters))
print("".join([secrets.choice(characters) for _ in range(16)]))
7
3GDLTHG3LLQGWQCE

secrets 还提供了几个 random 模块没有的函数:

  • secrets.randbits(n) 生成 n 个随机比特,以整数形式返回
  • secrets.randbelow(n) 返回 0 到 n 之间的随机整数,不包含 n
import secrets
print(secrets.randbits(16))
print(secrets.randbelow(100))
print(secrets.randbelow(6) + 1)  
60468
90
6

随机比特适合生成加密密钥,随机下限值适合做抽奖或随机索引。

此外, secrets 还提供了两个生成安全令牌的专用函数:

  • secrets.token_hex(n) 返回包含 n 个随机字节的十六进制字符串,适合直接当密钥或令牌用
  • secrets.token_urlsafe(n) 返回包含 n 个随机字节的 Base64 URL 安全字符串,适合生成重置密码链接中的令牌参数
import secrets

print(secrets.token_hex(16))
print(secrets.token_urlsafe(16))
deb22c5ae4792dac534337f891974876
8462YT76QewAPJ0doIv_CA

SystemRandom 类

secrets 的模块级函数不多( choicerandbelowrandbitstoken_hextoken_urlsafe ),如果你想要安全随机数,但还想用 random.randint 那些 API,可以用 secrets.SystemRandom 类。它是 random.Random 的子类, random 模块的函数它都有,只不过底层用的是安全随机源。

from secrets import SystemRandom

secure_random = SystemRandom()
print(secure_random.random())
print(secure_random.randint(1000, 9999))
print("".join(secure_random.choices("ABCDEFGHJKLPQRTUVWXY234679", k=16)))
0.8334571494524645
9828
X3DPFLTQDYE7WXVG

不过你通常不需要用到这么深。大多数安全场景用 secrets.choicesecrets.token_hexsecrets.token_urlsafe 就够了。

总结,什么场景用什么

游戏、模拟、做随机测试数据这类普通场景用 random 就行,速度快,需要时种子一设就能复现。测试场景用 random.seed 固定种子,保证每次跑出的随机序列一样。密码、令牌、加密密钥这类安全场景用 secrets ,不可预测。想用安全随机源但又舍不得 random 那套 API,那就上 secrets.SystemRandom