【ROS2】 Python 节点的开发流程

概述

ROS 2 的 Python 节点不会像 C++ 一样编译成二进制程序。

Python package 执行:

bash 复制代码
colcon build

主要作用是:

text 复制代码
安装 package
注册 ros2 run 入口
安装 package.xml、resource、launch、config 等元信息
生成 install/setup.bash 对应的环境信息

所以这里的 build 本质是:安装 + 注册

不是传统意义上的编译。

基本流程

  • 初始化
bash 复制代码
# 创建 workspace:
mkdir -p ~/robot_ws/src
cd ~/robot_ws/src
# 如果没有写入 .bashrc,每个新终端都要先 source ROS 2 环境
source /opt/ros/$ROS_DISTRO/setup.bash
# 创建 Python package:
cd ~/ros2_ws/src
# 如果这个指令中没有写完全依赖,后续需要在package.xml中补全
ros2 pkg create my_first_pkg --build-type ament_python --dependencies rclpy
# 创建节点文件
cd ~/ros2_ws/src/my_first_pkg/my_first_pkg
touch hello_node.py
chmod +x hello_node.py
  • 编写节点程序 略

  • 配置 package.xml

    如果创建功能包时没有写全依赖,在 package.xml 中声明依赖:

xml 复制代码
<exec_depend>rclpy</exec_depend>
<exec_depend>std_msgs</exec_depend>
  • 配置 setup.py 注册节点
bash 复制代码
vim ~/ros2_ws/src/my_first_pkg/setup.py
# 将 entry_points 字段改成:
# 格式:ros2 run 时的名字 = Python包名.文件名:main函数
entry_points={
    'console_scripts': [
        'hello_node = my_first_pkg.hello_node:main',
    ],
},
# 保存退出
  • 编译并运行
bash 复制代码
# 编译工作区
cd ~/ros2_ws
# (可选)根据package.xml自动安装依赖
# rosdep install --from-paths src --ignore-src -r -y
colcon build --symlink-install
# source 工作区环境
source install/setup.bash
# 运行节点
ros2 run my_first_pkg hello_node
# ctrl c 终止节点
  • 验证:
bash 复制代码
ros2 node list
ros2 topic list
ros2 topic echo /chatter

开发阶段建议固定使用:

bash 复制代码
colcon build --symlink-install

普通 build 可能会把 Python 文件复制到 install/ 目录。修改 src/ 下的 .py 文件后,运行时仍可能使用旧代码。

--symlink-install 会尽量让 install/ 中的 Python 文件链接到 src/ 源码。这样只修改已有 .py 业务代码时,通常不需要重新 build,只需要重启节点。

不需要重新 build 的情况

前提:

bash 复制代码
colcon build --symlink-install
source install/setup.bash

通常不需要重新 build 的修改:

text 复制代码
修改已有 .py 文件中的业务逻辑
修改回调函数内部实现
修改日志内容
修改 topic 名
修改 timer 周期
修改普通算法逻辑

操作方式:

bash 复制代码
# 停止旧节点后重新运行
ros2 run my_py_pkg talker

必须重新 build 的情况

以下情况必须重新 build:

text 复制代码
第一次创建 package
修改 setup.py
修改 package.xml
新增或修改 entry_points
新增 ros2 run 可执行入口
新增依赖
新增或修改 .msg/.srv/.action
新增 launch/config 文件安装规则
清理过 build/ install/ log/
未使用 --symlink-install 后修改 .py 文件

通用命令:

bash 复制代码
cd ~/robot_ws
colcon build --symlink-install
source install/setup.bash

修改自定义接口,并且其他包依赖该接口时:

bash 复制代码
colcon build --symlink-install --packages-up-to <使用该接口的包>
source install/setup.bash

判断表

修改内容 是否需要重新 build
只改已有 .py 业务代码 通常不需要
修改日志文本 通常不需要
修改回调内部逻辑 通常不需要
修改 topic 名 通常不需要
修改 timer 周期 通常不需要
修改 setup.py 需要
修改 package.xml 需要
新增 entry_points 需要
新增节点入口 需要
新增依赖 需要
修改 .msg/.srv/.action 需要
修改 launch/config 安装规则 需要
删除 build/ install/ log/ 需要
未使用 --symlink-install 后修改 .py 通常需要

规则总结

text 复制代码
Python 节点本身不编译成二进制。
colcon build 负责安装和注册 Python package。
开发阶段使用 colcon build --symlink-install。
只改已有 .py 业务代码,通常不需要重新 build。
修改 package 元信息、入口、依赖、接口或安装规则,必须重新 build。
相关推荐
zzzzzz3105 小时前
当产品经理说这个很简单:我用Python自动化处理奇葩需求的实战指南
python·pycharm·产品经理
雪隐6 小时前
个人电脑玩AI-06让5060 Ti给你打工——不光能画画,Qwen3-TTS还能学人说话,连我老板都信了!
人工智能·后端·python
兵慌码乱17 小时前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构
hboot19 小时前
AI工程师第三课 - 机器学习基础
python·scikit-learn·kaggle
顾林海1 天前
Agent入门阶段-编程基础-Python:流程控制
python·agent·ai编程
呱呱复呱呱1 天前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
曲幽1 天前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API
python·fastapi·web·translate·goldendict·libretranslate·stardict·pystardict
荣码1 天前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
兵慌码乱2 天前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
金銀銅鐵2 天前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学