4.3 KiB
4.3 KiB
天软平台和 Python 的交互
文档类型:模块摘要 是否可直接用于生成代码:否 是否含已验证可执行示例:否 是否含已验证反例:否 遇到不确定时跳转到:项目级部署文档、对应官方文档、pytsl_api.md、index.md
本页用于接入决策和最小链路确认,不替代项目级部署文档。
- 如果登录方式、凭证来源、位数、环境变量、连接通道或部署入口没有确认,不继续生成接入代码,直接回项目级部署文档或对应官方文档。
摘要
- 覆盖三类交互:Python 调用 TSL、TSL 调用 Python、落地服务器开启 Python 服务。
- 提供 COM/远程登录两种路径,以及
PyRun/PyCall体系。
怎么选路
| 场景 | 先选哪条路 | 最小前置条件 | 常见失败点 |
|---|---|---|---|
| Python 作为主控,远程执行或调用 TSL | Python 调 TSL | Python 环境、TSLPy 模块、可用连接方式(COM / 远程登录) | 位数不一致、环境变量没配好、服务器未登录 |
| TSL 脚本里需要调用现有 Python 代码 | TSL 调 Python | TSL 与 Python 位数一致、PYTHONHOME 等环境正确 |
Python 环境未就绪、模块找不到、网格场景不支持 |
| 落地服务器侧长期提供 Python 能力 | 落地服务器开启 Python 服务 | 服务端环境、部署权限、可维护的脚本入口 | 服务端环境和本地环境不一致、依赖未部署、运行权限不足 |
结构索引
- 支持版本
- Python 调用 TSL:配置步骤 / 接口说明 / 范例
- TSL 调用 Python:配置步骤 / 接口说明 / 范例
- do Python 方式
- 落地服务器开启 Python 服务
- sklearn 机器学习接口
- 附录与 FAQ
Python 调用 TSL(核心步骤)
- 先确认项目级部署文档里的天软目录、Python 目录、位数、连接通道和登录方式。
- 配置环境变量(天软目录、Python 目录)。
- 加载 TSLPy 模块(直接加载或修改包名)。
- 选择连接方式(COM / 远程登录)。
- 登录服务器后,再执行
RemoteExecute/RemoteCallFunc。 - 完成后显式断开连接。
主要接口(Python 侧)
- 服务器:
ConnectServer/LoginServer/Disconnect - 执行:
RemoteExecute/RemoteCallFunc - 系统参数:
SetSysParam/GetSysParam - 日期转换:
EncodeDate/DecodeDate/EncodeDateTime/DecodeDateTime
TSL 调用 Python(核心接口)
PyPutVar/PyGetVarPyRun(执行脚本)PyCall(调用 Python 函数,支持命名参数)PyError/PyRelease/PyEnsure
TSL 调用 Python(核心步骤)
- 先回项目级部署文档确认位数、
PYTHONHOME、解释器路径和可用模块。 - 用
PyEnsure确认 Python 运行时已经就绪。 - 需要把输入传给 Python 时,先用
PyPutVar放入变量。 - 选择执行方式:执行整段脚本用
PyRun,直接调函数用PyCall。 - 需要取回结果时,再用
PyGetVar读取输出变量。 - 失败时先看
PyError,结束后显式PyRelease。
最小前置条件
- Python 与 TSL 位数必须一致。
- 多版本 Python 需同步设置
PYTHONHOME。 - 落地前先决定是谁主控:Python 主控还是 TSL 主控。
do Python 方式
- 适合快速执行 Python 脚本,省去显式接口调用。
落地服务器开启 Python 服务(核心步骤)
- 先回项目级部署文档确认服务入口、部署权限、依赖目录和守护方式。
- 在服务器上准备与项目要求一致的 Python 运行时和依赖包。
- 放置一个稳定的 Python 脚本或服务入口,先只承载一条最小调用链。
- 按项目约定把这个入口接到天软侧的调用路径或调度入口。
- 用最小请求先验证“能启动、能调用、能返回”,再扩展业务逻辑。
- 再补日志、重启方式和运维监控;如果这些入口还没确认,不继续生成部署代码。
注意事项(精简)
- Python 与 TSL 位数必须一致。
- 多版本 Python 需同步设置
PYTHONHOME。 - TSL 调 Python 不支持网格调用。
- 出现调用失败时,优先先检查环境、位数和登录状态,再排查业务逻辑。
- 如果登录方式、凭证来源、位数、环境变量、连接通道或部署入口任一没有确认,不继续生成接入代码。