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