Lightweight web UI for managing, running, and monitoring Python experiments.
Project description
Pyruns
English | 简体中文
Python 实验管理 Web UI 工具:提供参数可视化、批量调度与资源监控功能
Pyruns 为 Python 脚本提供基于本地浏览器的图形界面。其主要功能包括:通过解析 argparse 生成可视化设置表单、支持特定语法实现参数网格的批量任务生成、管理并行调度队列,以及在浏览器端提供 ANSI 彩色日志的实时流式输出和跨任务的指标聚合导出。
当前工具无需修改原生业务代码,且所有流程均在本地环境执行。
pip install pyruns
pyr train.py # 启动 Web UI 并接管当前脚本
💡 解决的工程痛点
在日常的模型调参过程中,修改和记录不同参数组合的实验结果往往是一件极为繁琐且容易出错的事情:
- 编写多层嵌套的 Bash 循环脚本进行超参搜索不仅冗长且难以维护。
- 手动记录每一组参数以及它对应的实验结果费时费力,且随时间推移极易混淆或丢失。
- 在多参数并发执行时,控制台标准输出日志互相交错,错误定位困难。
Pyruns 提供的核心应对方案,是为了让繁琐的“参数修改与实验追踪”变得极其简单:
- ✅ 极简的任务生成:对现有
argparse进行非侵入式解析,并提供简洁、清晰可见的 Web UI 参数编辑器。支持声明式语法(如lr: 0.001 | 0.01)一键展开参数网格,生成互相隔离的任务。 - ✅ 便捷的历史任务管理:你可以非常方便地对之前运行过的实验任务进行记录追溯、条件搜索、复用以及状态管理。
- ✅ 流式隔离的实时查看:无须担心因为 SSH 终端断开而中断任务。任务运行时,在浏览器即可实时查看每个独立任务的输出与错误堆栈。
- ✅ 变量监视与一键导出报告:提供简易 API 监视任务运行过程中的关键指标,并在前端支持跨任务的比对,甚至一键合并且导出综合报表。
✨ 核心特性
| 特性 | 说明 |
|---|---|
| 🔌 静态参数解析 | 从源码中提取 argparse 定义来渲染 Web UI 表单;亦支持直接基于 yaml 文件的配置。 |
| 🧮 参数网格展开 | 支持使用 | 进行笛卡尔积排列或 (|) 进行配对组合,用于生成批量参数配置集。 |
| ⚡ 独立任务队列 | 内部实现任务队列缓冲,可选 Thread/Process pool 型执行器控制并发规模。 |
| 📋 状态看板管理 | 对任务进行 Pending/Running/Failed/Completed 状态流转管理,支持对历史配置的搜索与复用。 |
| 🖥️ 流式彩色终端 | 增量返回终端输出并完整支持 ANSI 转义字符渲染(如 tqdm)。 |
| 📊 指标监控聚合 | 提供 pyruns.record() 回调,帮助在多组参数实验后导出 CSV/JSON 等合并报告。 |
| 📁 环境参数快照 | 在 _pyruns/ 下建立与脚本结构绑定的运行时目录,快照当前环境与参数,防干扰且支持软删除安全机制。 |
🚀 启动方式
模式 1:基于 Argparse 的脚本接入
无需修改源码。Pyruns 通过 AST 分析器提取源码中 add_argument 的参数。
pyr train.py
这会在脚本所在目录下生成 _pyruns_/train/config_default.yaml,随后启动本地的 Web 服务(默认监听端口 8099)。
模式 2:基于 YAML 加载逻辑的接入
若您的源码直接通过读取外部 YAML 配置驱动并在代码内调用 pyruns.load():
# 首次运行:传入默认参数模板
pyr train.py my_config.yaml
此后,Pyruns 会接管参数调度及其相关环境变量:
pyr train.py
模式 3:CLI 命令行交互模式
如果你在无头服务器 (Headless Server) 上运行,或者更偏爱纯命令行操作,Pyruns 提供了一个与 Web UI 级别完全等同的 CLI 交互环境。
pyr cli train.py
这会自动构建和 Web UI 完全一样的工作区目录结构和配置,然后进入交互式的 REPL 终端:
Pyruns CLI (type 'help' for commands, 'exit' to quit)
pyruns> ls # 查看当前任务
pyruns> run 1 # 运行指定任务,并自动 stream 输出日志!
pyruns> status -i # 实时显示系统和 GPU 监控
任何通过 CLI 触发的操作和 Web UI 是 100% 数据互通和兼容的。
📝 实际上手示例
项目的 examples/ 目录下提供了可直接运行的完整示例脚本,分别对应两种接入模式。
示例 1:Argparse 原生支持(零改动接入)
对应目录:
examples/1_argparse_script/
下面是一个标准的 argparse 训练脚本,可以直接交给 Pyruns 接管——无需对原始代码做任何修改:
# examples/1_argparse_script/main.py
import pyruns
import argparse
import time
def main():
parser = argparse.ArgumentParser(description="A simple ML training script.")
parser.add_argument("--lr", type=float, default=0.001, help="Learning rate")
parser.add_argument("--epochs", type=int, default=10, help="Number of training epochs")
parser.add_argument("-b", "--batch_size", type=int, default=32, help="Batch size")
parser.add_argument("--optimizer", type=str, default="adam", choices=["adam", "sgd"])
args = parser.parse_args()
print(f"Hyperparameters: LR={args.lr}, Batch Size={args.batch_size}")
for epoch in range(1, args.epochs + 1):
time.sleep(0.5)
loss = 1.0 / (epoch * args.lr * 100)
print(f"Epoch {epoch}/{args.epochs} - Loss: {loss:.4f}")
# 可选:记录最终指标,脱离 Pyruns 环境时该调用被静默忽略
pyruns.record(last_loss=loss)
if __name__ == "__main__":
main()
使用方式:
# Pyruns 自动解析 argparse 参数并启动 Web UI
pyr main.py
Pyruns 通过 AST 静态分析自动提取 add_argument() 的所有定义(参数名、类型、默认值、help 文本),生成可编辑的 Web UI 表单。用户在界面修改参数后,Pyruns 会以命令行参数的形式将其传递给脚本——脚本本身的 parse_args() 逻辑完全不受影响。
示例 2:使用 pyruns.load() 加载 YAML 配置
对应目录:
examples/2_pyruns_config/
当训练脚本不使用命令行参数、而是直接读取 YAML 配置文件时,可以通过 pyruns.load() 完成接入。load() 返回的 ConfigNode 对象支持点号属性访问,嵌套结构会被自动递归封装:
# examples/2_pyruns_config/main1.py
import pyruns
import time
def main():
config = pyruns.load() # 自动绑定当前任务的 config.yaml
lr = config.lr
epochs = config.epochs
optimizer = config.optimizer
print(f"Hyperparameters: LR={lr}, Optimizer={optimizer}")
for epoch in range(1, epochs + 1):
time.sleep(0.5)
loss = 1.0 / (epoch * lr * 100)
print(f"Epoch {epoch}/{epochs} - Loss: {loss:.4f}")
if __name__ == "__main__":
main()
配套的默认配置文件 config1.yaml:
lr: 5e-3
epochs: 20
optimizer: sgd
batch_size: 64
dropout: 0.2
model: resnet50
使用方式:
# 首次运行:传入 YAML 模板,Pyruns 将其复制为 config_default.yaml
pyr main1.py config1.yaml
# 后续运行:无需再指定 YAML,Pyruns 自动使用已保存的模板
pyr main1.py
此外,pyruns.load() 也支持多层嵌套的 YAML 结构。以 config2.yaml 为例,项目、模型、训练三级分层的配置可以通过链式点号一路访问到底:
# config2.yaml — 三级嵌套结构
project:
name: "DeepSense_Alpha"
version: 1.2
output_dir: "./results"
model:
type: "Transformer"
layers: 12
dropout: 0.1
training:
hyperparams:
lr: 0.0005
epochs: 8
optimizer: "AdamW"
resources:
device: "cuda"
precision: "fp16"
gpu_config:
memory_frac: 0.8
在脚本中通过点号链式访问即可读取任意层级的值:
config = pyruns.load()
config.project.name # "DeepSense_Alpha"
config.training.hyperparams.lr # 0.0005
config.training.resources.device # "cuda"
🎯 界面模块
🔧 Generator — 简洁清晰的参数编辑器
在左侧提供清晰可见的结构化表单控制超参数修改,并支持声明化批量语法;右侧可实时预览将会并行生成的批量实验任务。通过(Pin)功能可以方便地标记核心参数。
📦 Manager — 便捷的历史任务记录与管理
核心的任务管理面板。能够极其方便地监控、搜索并管理所有生成的任务队列。支持勾选进行并发执行限制;点击进入任务卡片,可查阅其精准的参数快照 (config.yaml) 历史记录。
🔥 点击查看卡片内部详情弹窗特性
| 特性 | 视图预览 |
|---|---|
| 生命周期总览 重跑历史与 PIDs 记录 |
|
| 绝对隔离快照 独享的 config.yaml 映射 |
|
| 实验笔记记录 支持随时修改的实验副文本 |
|
| 环境变量溯源 完整还原任务启动时的全部系统变量 |
📈 Monitor — 实时查看与一键导出报告
将处于活跃状态的任务的标准输流出实时定向到浏览器终端。同时,监视到的任务运行指标(如 Loss、Accuracy 等),在此支持跨任务勾选,一键导出聚合比对报表。
🧪 批量生成语法
在 Generator 的代码域内支持特定的管道解析语法,用于描述性构建执行计划:
笛卡尔积组合 | — 全排列组装(如 3 × 2 = 6 个独立任务):
learning_rate: 0.001 | 0.01 | 0.1
batch_size: 32 | 64
一一配对映射 (|) — 等长对应(共 3 个独立任务):
seed: (1 | 2 | 3)
experiment_name: (exp_a | exp_b | exp_c)
支持数字序列区间(如:lr: 1:10:2)。详细结构规则见 批量构建语法说明。
📂 运行区结构原理
Pyruns 采用隔离持久化策略。针对单一入口脚本所生成的执行缓存符合以下文件树形规约:
your_project/
├── train.py
└── _pyruns_/
├── _pyruns_settings.yaml # 全局端口、并发数相关配制
└── train/ # 对应该脚本的独立命名空间
├── script_info.json # 记录脚本路径与环境依赖
├── config_default.yaml # UI 表单所需的参数初始骨架
└── tasks/
├── fast_tuning_[1-of-6]/
│ ├── task_info.json # 元数据状态机(存放执行PID、启停时间、监控数据等)
│ ├── config.yaml # 该任务启动时的确切参数配置切片
│ └── run_logs/
│ ├── run1.log # 主流终端输出
│ └── error.log # 非零状态码退出时的标准错误分离堆栈
└── .trash/ # Manager界面执行的非实质性软删除回收站
底层调用逻辑在执行队列发出 Run 信号时生效,执行器将 config.yaml 对应路径经由 __PYRUNS_CONFIG__ 环境变量置入被唤醒的子进程。
📖 补充文档
| 文档部分 | 说明 |
|---|---|
| 📗 安装部署与初次接入 | 环境说明与第一个示例运作 |
| 📘 批量语法细则 | 复杂网格规则与类型推断行为 |
| 💻 命令行 CLI 交互控制 | 在无头服务器/纯终端使用 REPL 环境管理全部流程的操作详解 |
| 📕 界面高级操作与控制 | Manager执行限制细节及报表数据的导出等 |
| 📙 配置流转与沙盒说明 | Node树层级、优先读取顺位判定 |
| 📓 API 接口文档 | 深入代码端的 read() / load() 及 record() 功能介绍 |
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pyruns-0.1.tar.gz.
File metadata
- Download URL: pyruns-0.1.tar.gz
- Upload date:
- Size: 129.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b9667369d92555068cb9597a33587a7b1979fef0af0206d2b93ab75af511584f
|
|
| MD5 |
a91a4e215d1e61a8ccd0bb56899499f2
|
|
| BLAKE2b-256 |
b48f3a4caeb10de621b8751a41521c50fbb0338a2e1523ef8fc0190e810e9a57
|
File details
Details for the file pyruns-0.1-py3-none-any.whl.
File metadata
- Download URL: pyruns-0.1-py3-none-any.whl
- Upload date:
- Size: 125.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c9e4267a3a40f3e7413aa36b59b7dcbacab3bafafcea5e16c5f3ac2f1d06fab8
|
|
| MD5 |
6911941b6f6104a26536ef79c7bfc0e0
|
|
| BLAKE2b-256 |
b8f7147418cc5d8c8b3e3f1bc319abf0851304797766b5e356f5c774151b6eca
|