实验室自动化工具包Skill pylabrobot

PyLabRobot 是一个用于实验室自动化的Python工具包,支持控制液体处理机器人、板阅读器、泵、加热振荡器、培养箱、离心机等多种设备,提供资源管理、硬件后端集成、模拟和可视化功能,适用于生物医药、化学等领域的自动化实验工作流程。关键词:实验室自动化、Python编程、液体处理、硬件控制、资源管理、模拟协议、数据分析。

嵌入式软件 0 次安装 0 次浏览 更新于 3/16/2026

名称: pylabrobot 描述: 用于控制液体处理器、板阅读器、泵、加热振荡器、培养箱、离心机和分析设备的实验室自动化工具包。当自动化实验室工作流程、编程液体处理机器人(Hamilton STAR、Opentrons OT-2、Tecan EVO)、集成实验室设备、管理台面布局和资源(板、吸头、容器)、读取板或创建可复现的实验室协议时,使用此技能。适用于模拟协议和物理硬件控制。

PyLabRobot

概述

PyLabRobot 是一个硬件无关的纯Python软件开发工具包,用于自动化和自主实验室。使用此技能通过统一的Python接口控制液体处理机器人、板阅读器、泵、加热振荡器、培养箱、离心机和其他实验室自动化设备,该接口跨平台工作(Windows、macOS、Linux)。

何时使用此技能

使用此技能当:

  • 编程液体处理机器人(Hamilton STAR/STARlet、Opentrons OT-2、Tecan EVO)
  • 自动化涉及移液、样品准备或分析测量的实验室工作流程
  • 管理台面布局和实验室资源(板、吸头、容器、槽)
  • 集成多个实验室设备(液体处理器、板阅读器、加热振荡器、泵)
  • 创建具有状态管理的可复现实验室协议
  • 在物理硬件上运行之前模拟协议
  • 使用 BMG CLARIOstar 或其他支持的板阅读器读取板
  • 控制温度、振荡、离心或其他物料处理操作
  • 在Python中处理实验室自动化

核心能力

PyLabRobot 通过六个主要能力领域提供全面的实验室自动化,每个领域在 references/ 目录中有详细说明:

1. 液体处理 (references/liquid-handling.md)

控制液体处理机器人进行吸液、分液和液体转移。关键操作包括:

  • 基本操作:吸液、分液、在孔之间转移液体
  • 吸头管理:自动拾取、丢弃和跟踪移液吸头
  • 高级技术:多通道移液、连续稀释、板复制
  • 体积跟踪:自动跟踪孔中的液体体积
  • 硬件支持:Hamilton STAR/STARlet、Opentrons OT-2、Tecan EVO 等

2. 资源管理 (references/resources.md)

在层次系统中管理实验室资源:

  • 资源类型:板、吸头架、槽、管、载体和自定义实验器具
  • 台面布局:将资源分配到台面位置,使用坐标系
  • 状态管理:跟踪吸头存在、液体体积和资源状态
  • 序列化:从JSON文件保存和加载台面布局和状态
  • 资源发现:通过直观API访问孔、吸头和容器

3. 硬件后端 (references/hardware-backends.md)

通过后端抽象连接到多样化的实验室设备:

  • 液体处理器:Hamilton STAR(全面支持)、Opentrons OT-2、Tecan EVO
  • 模拟:ChatterboxBackend 用于无需硬件的协议测试
  • 平台支持:在 Windows、macOS、Linux 和 Raspberry Pi 上工作
  • 后端切换:通过交换后端更改机器人,无需重写协议

4. 分析设备 (references/analytical-equipment.md)

集成板阅读器和分析仪器:

  • 板阅读器:BMG CLARIOstar 用于吸光度、发光、荧光
  • 天平:Mettler Toledo 集成用于质量测量
  • 集成模式:结合液体处理器和分析设备
  • 自动化工作流程:在设备之间自动移动板

5. 物料处理 (references/material-handling.md)

控制环境和物料处理设备:

  • 加热振荡器:Hamilton HeaterShaker、Inheco ThermoShake
  • 培养箱:Inheco 和 Thermo Fisher 培养箱,带温度控制
  • 离心机:Agilent VSpin 带桶定位和旋转控制
  • :Cole Parmer Masterflex 用于流体泵操作
  • 温度控制:在协议期间设置和监控温度

6. 可视化与模拟 (references/visualization.md)

可视化和模拟实验室协议:

  • 浏览器可视化器:台面状态的实时3D可视化
  • 模拟模式:无需物理硬件测试协议
  • 状态跟踪:可视化监控吸头存在和液体体积
  • 台面编辑器:设计台面布局的图形工具
  • 协议验证:在硬件上运行之前验证协议

快速开始

要开始使用 PyLabRobot,安装包并初始化液体处理器:

# 安装 PyLabRobot
# pip install pylabrobot

# 基本液体处理设置
from pylabrobot.liquid_handling import LiquidHandler
from pylabrobot.liquid_handling.backends import STAR
from pylabrobot.resources import STARLetDeck

# 初始化液体处理器
lh = LiquidHandler(backend=STAR(), deck=STARLetDeck())
await lh.setup()

# 基本操作
await lh.pick_up_tips(tip_rack["A1:H1"])
await lh.aspirate(plate["A1"], vols=100)
await lh.dispense(plate["A2"], vols=100)
await lh.drop_tips()

使用参考资料

此技能通过多个参考文件组织详细信息。加载相关参考当:

  • 液体处理:编写移液协议、吸头管理、转移
  • 资源:定义台面布局、管理板/吸头、自定义实验器具
  • 硬件后端:连接到特定机器人、切换平台
  • 分析设备:集成板阅读器、天平或分析设备
  • 物料处理:使用加热振荡器、培养箱、离心机、泵
  • 可视化:模拟协议、可视化台面状态

所有参考文件可以在 references/ 目录中找到,包含全面示例、API使用模式和最佳实践。

最佳实践

当使用 PyLabRobot 创建实验室自动化协议时:

  1. 从模拟开始:使用 ChatterboxBackend 和可视化器在硬件上运行之前测试协议
  2. 启用跟踪:打开吸头跟踪和体积跟踪以进行准确状态管理
  3. 资源命名:为所有资源(板、吸头架、容器)使用清晰、描述性名称
  4. 状态序列化:将台面布局和状态保存到JSON以实现可复现性
  5. 错误处理:为硬件操作实现适当的异步错误处理
  6. 温度控制:尽早设置温度,因为加热/冷却需要时间
  7. 模块化协议:将复杂工作流程分解为可重用函数
  8. 文档:参考官方文档 https://docs.pylabrobot.org 获取最新功能

常见工作流程

液体转移协议

# 设置
lh = LiquidHandler(backend=STAR(), deck=STARLetDeck())
await lh.setup()

# 定义资源
tip_rack = TIP_CAR_480_A00(name="tip_rack")
source_plate = Cos_96_DW_1mL(name="source")
dest_plate = Cos_96_DW_1mL(name="dest")

lh.deck.assign_child_resource(tip_rack, rails=1)
lh.deck.assign_child_resource(source_plate, rails=10)
lh.deck.assign_child_resource(dest_plate, rails=15)

# 转移协议
await lh.pick_up_tips(tip_rack["A1:H1"])
await lh.transfer(source_plate["A1:H12"], dest_plate["A1:H12"], vols=100)
await lh.drop_tips()

板读取工作流程

# 设置板阅读器
from pylabrobot.plate_reading import PlateReader
from pylabrobot.plate_reading.clario_star_backend import CLARIOstarBackend

pr = PlateReader(name="CLARIOstar", backend=CLARIOstarBackend())
await pr.setup()

# 设置温度并读取
await pr.set_temperature(37)
await pr.open()
# (手动或机器人加载板)
await pr.close()
data = await pr.read_absorbance(wavelength=450)

附加资源

对于特定能力的详细使用,请参考 references/ 目录中的相应参考文件。