承接 fontebasso/json-to-toon 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱: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.

统计信息

  • 总下载量: 16
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 5
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

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

其他信息

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

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固