Skip to content

Latest commit

 

History

History
111 lines (79 loc) · 2.82 KB

File metadata and controls

111 lines (79 loc) · 2.82 KB

GPython Engine · Python 脚本引擎

Go Version Engine Type

基于 gpython 的纯 Go Python 3.4 子集脚本引擎

中文 · English · 日本語


概述

GPython 引擎使用 go-python/gpython 库,为 Go 应用提供 Python 3.4 子集的脚本执行能力。无需 CPython 依赖,纯 Go 实现,跨平台编译零障碍。

引擎特性

特性 说明
底层库 github.com/go-python/gpython v0.2.0
语言版本 Python 3.4 子集
标准库 内置 systimemath 等原生模块
线程安全 双锁模式(RWMutex + execMutex
热更新 支持 StartWatch / StopWatch
类型常量 scriptEngine.GPythonType

安装

go get github.com/tx7do/go-scripts/gpython

快速开始

package main

import (
    "context"
    "fmt"
    "log"

    scriptEngine "github.com/tx7do/go-scripts"
    _ "github.com/tx7do/go-scripts/gpython" // 注册 GPython 引擎
)

func main() {
    eng, err := scriptEngine.NewScriptEngine(scriptEngine.GPythonType)
    if err != nil {
        log.Fatal(err)
    }
    defer eng.Close()

    ctx := context.Background()
    if err := eng.Init(ctx); err != nil {
        log.Fatal(err)
    }

    // 注入宿主变量
    _ = eng.RegisterGlobal("name", "world")

    // 注册宿主函数
    _ = eng.RegisterFunction("greet", func(name string) string {
        return fmt.Sprintf("Hello, %s!", name)
    })

    // 执行 Python 脚本
    result, _ := eng.ExecuteString(ctx, "hello.py", `greet(name)`)
    fmt.Println(result)
}

API 参考

方法 说明
Init(ctx) 创建 gpython 解释器上下文和主模块
Close() 关闭解释器,释放资源
LoadString(ctx, name, code) 编译 Python 源码并加入执行队列
Execute(ctx) 顺序执行队列中所有脚本
ExecuteString(ctx, name, code) 编译并立即执行内联 Python 代码
RegisterGlobal(name, value) 注入 Go 值为 Python 全局变量
RegisterFunction(name, fn) 注册 Go 函数为 Python 可调用对象
CallFunction(ctx, name, args...) 调用 Python 函数
RegisterModule(name, module) 注册模块(键值映射为 模块名_键名 全局变量)
StartWatch(ctx, key) 启动脚本热更新监听
StopWatch(key) 停止热更新监听

测试

cd gpython && go test -v ./...

相关文档

License

MIT License