Add your description here
Project description
简介
Solaris 是 SeerAPI 的核心部分,用于解析和整理赛尔号三平台(Flash、HTML5、Unity)客户端数据。通过标准化的数据处理流程,将原始客户端数据转换为 seerapi-models 定义的标准结构,并输出为 JSON 文件、数据库记录和相关资源文件。
功能特性
- 🎮 多平台支持: 支持 Flash、HTML5、Unity 三个平台的数据解析
- 📊 数据标准化: 将客户端原始数据转换为标准化格式
- 🗃️ 多格式输出: 支持带 Schema 的 JSON 表格、SQLite 数据库输出
- 🔧 模块化架构: 基于插件式的解析器和分析器架构,易于扩展
- ⚡ 命令行接口: 提供简洁易用的 CLI 工具
安装
确保你的 Python 版本 >= 3.10,然后安装 Solaris。
pip install seerapi-solaris
# 如果你使用 uv
uv add seerapi-solaris
使用方法
Solaris 提供了两个主要命令:parse 和 analyze。
基本用法
# 查看帮助
uv run solaris --help
# 查看版本
uv run solaris --version
数据解析 (parse)
将Unity客户端二进制数据文件解析为中间格式:
# 基本解析
solaris parse --source-dir /path/to/client/data --output-dir /path/to/output
# 查看可用的解析器
solaris parse --list-parsers
# 使用自定义解析器包
solaris parse --package-name my.custom.parsers
数据分析 (analyze)
将解析后的数据进行分析并输出为最终格式:
# 输出为 JSON 格式(默认)
solaris analyze --source-dir ./source --json-output-dir ./data --schema-output-dir ./schema
# 输出为数据库格式
solaris analyze --output-mode db --db-url solaris.db
# 同时输出 JSON 和数据库
solaris analyze --output-mode all
# 指定 API 信息
solaris analyze --api-url https://api.example.com --api-version v1beta
# 查看可用的分析器
solaris analyze --list-analyzers
命令参数详解
parse 命令
| 参数 | 默认值 | 说明 |
|---|---|---|
--source-dir |
source |
客户端数据源目录 |
--output-dir |
output |
解析结果输出目录 |
--package-name |
solaris.parse.parsers |
解析器包名(可多个) |
-l, --list-parsers |
- | 显示所有可用解析器 |
analyze 命令
| 参数 | 默认值 | 说明 |
|---|---|---|
-w, --source-dir |
环境变量或 ./source |
数据源目录 |
-m, --output-mode |
json |
输出模式:json/db/all |
--json-output-dir |
data |
JSON 文件输出目录 |
--schema-output-dir |
schema |
JSON Schema 输出目录 |
-d, --db-url |
solaris.db |
数据库文件路径 |
--api-url |
环境变量 | API 基础 URL |
--api-version |
环境变量 | API 版本号 |
--package-name |
solaris.analyze.analyzers |
分析器包名(可多个) |
-l, --list-analyzers |
- | 显示所有可用分析器 |
环境变量
Solaris 支持通过环境变量进行配置:
# 数据源基础目录
export SOLARIS_DATA_BASE_DIR="/path/to/data"
# API 配置
export SOLARIS_API_URL="https://api.example.com"
export SOLARIS_API_VERSION="v1beta"
# 下列环境变量无法通过命令行指定
# 在仅设置SOLARIS_DATA_BASE_DIR的情况下,各分类数据源目录为 SOLARIS_DATA_BASE_DIR/[patch|html5|unity|flash]
# 设置下列变量以指定单个分类的目录
export SOLARIS_DATA_PATCH_DIR="/path/to/patch"
export SOLARIS_DATA_HTML5_DIR="/path/to/html5"
export SOLARIS_DATA_UNITY_DIR="/path/to/unity"
export SOLARIS_DATA_FLASH_DIR="/path/to/flash"
# 在输出中添加源信息
export SOLARIS_API_DATA_SOURCE="https://github.com/example/data.git"
export SOLARIS_API_DATA_VERSION="v1beta"
export SOLARIS_API_PATCH_SOURCE="https://example.com/patch"
export SOLARIS_API_PATCH_VERSION="v1beta"
项目结构
packages/solaris/
├── solaris/
│ ├── analyze/ # 数据分析模块
│ ├── cli/ # 命令行接口
│ │ ├── analyze.py # analyze 命令实现
│ │ └── parse.py # parse 命令实现
│ ├── parse/ # 数据解析模块
│ ├── settings.py # 配置管理
│ ├── typing.py # 类型定义
│ └── utils.py # 工具函数
├── docs/ # 开发文档
│ ├── PARSER_GUIDE.md
│ ├── ANALYZER_GUIDE.md
│ └── README.md
└── pyproject.toml
输出格式
JSON 输出
- 数据文件: 结构化的 JSON 表格,包含解析后的游戏数据
- Schema 文件: 对应的 JSON Schema 定义,用于数据验证
- 元数据: API 版本、URL 等元信息
数据库输出
- SQLite 数据库: 包含所有解析数据的单一数据库文件
开发
环境要求
- Python >= 3.10
- 依赖管理:使用
uv或pip
代码风格
项目使用 Ruff 进行代码格式化和检查:
# 安装开发依赖
uv sync
# 代码检查
uv run ruff check .
# 代码格式化
uv run ruff format .
扩展开发
添加新的解析器
- 在
solaris/parse/parsers/下创建新模块 - 继承
BaseParser类 - 实现
parse()方法
添加新的分析器
- 在
solaris/analyze/analyzers/下创建新模块 - 继承
BaseAnalyzer类 - 实现数据分析逻辑
贡献
目前该项目的parser只有寥寥几个,欢迎提交更多的parser!
许可证
本项目基于 MIT License 开源。
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file seerapi_solaris-106.0.0.tar.gz.
File metadata
- Download URL: seerapi_solaris-106.0.0.tar.gz
- Upload date:
- Size: 142.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.17
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bc9604bb540897ea77626ccee89b41272b05171f4f089059af337ffcdbc37227
|
|
| MD5 |
7f1053daf241820ef0af0c9816c75ef7
|
|
| BLAKE2b-256 |
c6c7310906b38111aa352f46e01a061c1cefc540831cc8a7cb82eb2ec25360a0
|
File details
Details for the file seerapi_solaris-106.0.0-py3-none-any.whl.
File metadata
- Download URL: seerapi_solaris-106.0.0-py3-none-any.whl
- Upload date:
- Size: 271.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.17
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
628d66caabf1628c08cd45cc66a0963c5aeda1626e29ab739ad3016fbb86040f
|
|
| MD5 |
3ec9048912b6abd8ef751a7ea0a10086
|
|
| BLAKE2b-256 |
d7ddf6f4048440447c9b64af807584a15082dd136ae89950534d8c8dcead3c98
|