fontebasso/json-to-toon
最新稳定版本:1.0.0
Composer 安装命令:
composer require fontebasso/json-to-toon
包简介
json-to-toon converts verbose JSON into a lightweight, LLM-friendly “Toon” format — optimized for ChatGPT and other AI models to cut token usage, boost context efficiency, and keep responses sharp.
README 文档
README
json-to-toon is a lightweight PHP library that converts verbose JSON into a compact, LLM-optimized format called TOON.
The TOON format preserves structure while minimizing token usage, improving context efficiency for large language models such as ChatGPT and Claude.
This implementation follows the TOON Specification v2.0, supporting arrays, nested objects, primitives, and non-uniform structures — including compact representation of associative and nested data.
Installation
You can install the library via Composer:
composer require fontebasso/json-to-toon
Overview
Traditional JSON structures are often verbose and redundant, especially when serialized for language models.
json-to-toon introduces a concise syntax that encodes data in a tabular form, preserving semantics while reducing size.
Example
Input JSON:
[
{"id": 1, "name": "Alice", "role": "admin"},
{"id": 2, "name": "Bob", "role": "user"}
]
Converted Toon:
users[2]{id,name,role}:
1,Alice,admin
2,Bob,user
This representation is shorter, token-efficient, and ideal for transmitting structured context to LLMs such as ChatGPT or Claude.
Usage
From PHP Array
<?php use Fontebasso\JsonToToon\Toon; require 'vendor/autoload.php'; $data = [ ["id" => 1, "name" => "Alice", "role" => "admin"], ["id" => 2, "name" => "Bob", "role" => "user"] ]; $toon = Toon::encode('users', $data); echo $toon;
From JSON String
<?php use Fontebasso\JsonToToon\Toon; require 'vendor/autoload.php'; $json = '[ {"id": 1, "name": "Alice", "role": "admin"}, {"id": 2, "name": "Bob", "role": "user"} ]'; $toon = Toon::encode('users', $json); echo $toon;
Output
users[2]{id,name,role}:
1,Alice,admin
2,Bob,user
Compact Mode
json-to-toon automatically encodes associative objects using the compact TOON syntax:
$data = [ 'meta' => ['a' => 1, 'b' => 2], 'tags' => ['x', 'y'], ]; echo Toon::encode('data', $data);
Output
data:
meta{a=1;b=2}
tags[2]{value}:
x
y
Nested arrays are represented recursively:
profile{name=Alice;skills=[PHP|Go]}
Tests
Run the PHPUnit suite:
composer test
Open the generated coverage report at:
coverage/html/index.html
Continuous Integration
The repository includes a GitHub Actions workflow that automatically runs tests on PHP 8.2, 8.3, and 8.4 for every push or pull request to main.
License
This library is licensed under the MIT License. See the LICENSE file for details.
统计信息
- 总下载量: 3
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-11-12