fontebasso/json-to-toon 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

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

Tests License: MIT

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

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-11-12