定制 maximal/tsv 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

maximal/tsv

最新稳定版本:v1.0

Composer 安装命令:

composer require maximal/tsv

包简介

Library for working with the tab-separated values format (TSV).

README 文档

README

This is a small PHP library for working with the tab-separated values format (TSV) without any dependencies.

Installation

Install the library via Composer:

composer require maximal/tsv

Usage

require_once __DIR__ . '/vendor/autoload.php';

use Maximal\Tsv\Tsv;

// Get TSV text for the given two-dimensional data table
$tsvString = Tsv::getTsv($dataTable);
// Every cell value in `Tsv::getTsv()` call will be cast to string using `(string)$value`.
// Make sure all values are castable, e.g. all the classes have `__toString()` methods.

// Get two-dimensional data table for the given TSV text
$table = Tsv::getTable($tsvString);

Value escaping

This library uses the most common special characters escaping:

Escape Sequence Character
\t tab
\r carriage return
\n line feed
\\ backslash

This works two-way: TSV → array → TSV conversion gives the initial TSV text.

Transitive Equivalence

Let’s review an example of chained table → TSV → table → TSV conversion:

// Initial two-dimensional data table
$dataTable = [[/* ... */], [/* ... */], /* ... */];
// $dataTable is `array<array<mixed>>`

// TSV text from the initial data
$tsv = Tsv::getTsv($dataTable);
// $tsv is `string`

// Data table taken back from resulting TSV text
$tableFromTsv = Tsv::getTable($tsv);
// $tableFromTsv is `list<list<string>>`

// TSV text again
$tsvFromTable = Tsv::getTsv($dataTable);
// $tsvFromTable is `string`

// `$tsv === $tsvFromTable` equality is guaranteed
// `$dataTable === $tsvFromTable` equality is NOT guaranteed

Here, $tsv text is guaranteed to be equal to $tsvFromTable: both are strings and similarly formatted.

However, $dataTable is not guaranteed to be equal to $tableFromTsv because the initial array can have various keys and different value types (array<array<mixed>>) while the resulting array is strictly a collection of list of strings (list<list<string>>).

Coding Style

PER-3T / PSR-12T (PHP’s standard PER-3 / PSR-12 with SmartTabs instead of spaces).

Author

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-09-21