【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。
相关推荐
计算机安禾1 小时前
【c++面向对象编程】第12篇:继承(二):构造与析构顺序,继承中的构造函数
开发语言·c++
知识分享小能手1 小时前
R语言入门学习教程,从入门到精通,R语言获取数据 (7)
开发语言·学习·r语言
m0_624578591 小时前
SQL数据更新时如何减少锁表时间_合理控制事务边界与并发
jvm·数据库·python
曲幽1 小时前
让 FastAPI Agent 思考不阻塞:手把手教你实现异步任务与后台处理方案
redis·python·agent·fastapi·web·async·celery·ai agent·backgroundtask
原来是猿2 小时前
网络计算器:理解序列化与反序列化(下)
linux·开发语言·网络·网络协议·json·php
2401_867623982 小时前
如何提取SQL日期中的月份_使用MONTH函数快速过滤
jvm·数据库·python
ㄟ留恋さ寂寞2 小时前
JavaScript中箭头函数在大括号省略时的隐式返回机制
jvm·数据库·python
_waylau2 小时前
“Java+AI全栈工程师”问答02:Spring Boot 自动配置原理
java·开发语言·spring boot·后端·spring
JAVA面经实录9172 小时前
Java架构师最终完整版学习路线图
java·开发语言·学习