Metadata-Version: 2.4
Name: vrl-python
Version: 0.1.0
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Rust
License-File: LICENSE
Summary: Python bindings for Vector Remap Language (VRL)
Keywords: vrl,vector,data-processing,etl
Author-email: JQQ <jqq1716@gmail.com>
License: MIT
Requires-Python: >=3.8
Description-Content-Type: text/markdown; charset=UTF-8; variant=GFM
Project-URL: Homepage, https://github.com/yourusername/vrl-python
Project-URL: Repository, https://github.com/yourusername/vrl-python
Project-URL: Documentation, https://github.com/yourusername/vrl-python#readme

# vrl-python
VRL Python SDK Project

基于PyO3封装的Vector Remap Language (VRL) Python SDK

## Python 开发者快速使用指南 / Quick Start for Python Developers

> 包名（PyPI）：`vrl-python` ；导入模块：`vrl_python`

### 安装 / Install

```bash
# 使用 pip（推荐） / Use pip (recommended)
pip install vrl-python

# 使用 uv / Use uv
uv add vrl-python

# 使用 Poetry / Use Poetry
poetry add vrl-python
```

> 运行环境 / Requirements：Python >= 3.8

### 快速开始 / Quick Start

```python
# 中文：从 vrl_python 导入 VRLRuntime，并运行一个最小示例
# English: Import VRLRuntime from vrl_python and run a minimal example
from vrl_python import VRLRuntime

runtime = VRLRuntime()  # 中文：使用默认UTC；English: uses UTC by default

program = ".field = \"value\""  # 中文：设置字段；English: set a field
event = {}  # 中文：输入事件；English: input event

result = runtime.execute(program, event)
print(result.processed_event)  # {'field': 'value'}
```

### 一次性执行（便捷方法） / One-shot execution (convenience)

```python
# 中文：无需先创建实例，直接编译+执行
# English: compile+execute in one call without creating an instance
from vrl_python import VRLRuntime

result = VRLRuntime.run('.greeting = "hello"', {})
print(result.processed_event)  # {'greeting': 'hello'}
```

### 语法检查 / Syntax Check

```python
# 中文：仅检查语法，不执行
# English: check syntax only, no execution
from vrl_python import VRLRuntime

diagnostic = VRLRuntime.check_syntax('.parsed = parse_json(.message)')
if diagnostic is None:
    print('✅ 语法正确 / Syntax OK')
else:
    print('❌ 发现错误 / Errors found:', diagnostic.messages)
    print(diagnostic.formatted_message)
```

---

项目概述

本项目旨在为Vector的VRL语言提供一个Python SDK封装，使Python开发者能够直接在Python环境中使用VRL的强大数据处理能力。封装基于PyO3实现，提供高性能的Rust底层实现和友好的Python API。

功能特性

• ✅ 编译和执行VRL程序

• ✅ 支持事件数据处理和转换

• ✅ 完整的错误处理和诊断信息

• ✅ **VRL语法检查和诊断** (新增)

• ✅ **完整的类型提示支持** (新增)

• ✅ 时区支持

• ✅ 性能监控（执行时间统计）

• ✅ 预编译和缓存支持

快速开始

安装

```
pip install vrl-python
```


基本用法

from vrl_python import VRLRuntime

# 初始化运行时
runtime = VRLRuntime()

# 定义VRL程序
program = """
.message = parse_json!(.message)
.new_field = "new value"
"""

# 准备输入事件
event = {
"message": '{"key": "value"}',
"timestamp": "2023-01-01T00:00:00Z"
}

# 执行VRL程序
result = runtime.execute(program, event)

print(result.processed_event)
# 输出: {'message': {'key': 'value'}, 'timestamp': '2023-01-01T00:00:00Z', 'new_field': 'new value'}


VRL语法检查

from vrl_python import VRLRuntime

# 检查VRL程序语法
program = """
.parsed = parse_json(.message)
"""

diagnostic = VRLRuntime.check_syntax(program)
if diagnostic is None:
    print("✅ 语法正确")
else:
    print(f"❌ 发现错误: {diagnostic.messages}")
    print(diagnostic.formatted_message)  # 详细的错误信息，包含位置和建议


版本管理

本项目使用 `bump-my-version` 管理版本号，确保 Rust 和 Python 版本同步。

## 常用命令

make version        # 查看当前版本
make check-version  # 检查版本一致性
make bump-patch     # 升级补丁版本 (0.1.0 -> 0.1.1)
make bump-minor     # 升级次版本 (0.1.0 -> 0.2.0)
make bump-major     # 升级主版本 (0.1.0 -> 1.0.0)

详细文档：`VERSION_MANAGEMENT.md`

开发计划

阶段1: 核心功能实现 ✅ (已完成)
• ✅ 项目初始化与PyO3配置

• ✅ 基本VRL编译执行功能

• ✅ 错误处理与诊断信息

• ✅ 单元测试框架搭建（11个测试全部通过）

• ✅ 示例代码和文档

阶段2: 高级功能扩展
自定义函数支持

时区配置支持

性能优化与缓存

文档生成

阶段3: 生产准备
CI/CD流水线

性能基准测试

PyPI发布准备

开发环境

• Rust 1.70+

• Python 3.8+

• RustRover IDE (推荐)

• maturin (构建工具)

CI/CD

• ✅ GitHub Actions 自动化测试

• ✅ 多平台支持 (Linux, macOS, Windows)

• ✅ 自动发布到 PyPI/TestPyPI

• ✅ Trusted Publishing (安全发布)

构建与测试

## 使用 Makefile（推荐）

# 查看所有可用命令
make help

# 安装开发环境
make install

# 开发模式构建
make dev

# 运行测试
make test

# 运行示例
make examples

# 完整检查（格式化 + 检查 + 测试）
make check


## 手动命令

# 创建虚拟环境
uv venv
source .venv/bin/activate

# 安装依赖
uv pip install maturin pytest pytest-cov

# 开发模式构建
maturin develop

# 发布模式构建
maturin develop --release

# 运行测试
pytest tests/ -v

# 运行示例
python examples/basic_usage.py


贡献指南

欢迎贡献！请遵循以下步骤：

1. Fork仓库并创建分支
2. 提交代码变更
3. 添加/更新测试用例
4. 运行测试确保通过
5. 提交Pull Request

技术参考

• https://vector.dev/docs/reference/vrl/

• https://pyo3.rs/

• https://github.com/vectordotdev/vrl

许可证

MIT
