thibaultvanc/laravel-formatter

一个格式化库,可以在XML、CSV、JSON、TXT、YAML和其他一些格式之间转换数据输出。

3.1.1 2018-06-27 14:37 UTC

This package is auto-updated.

Last update: 2024-09-11 20:04:57 UTC


README

  • 添加对 Laravel 7.* 的兼容性
  • 更新对 Laravel 6 & phpunit 8 的支持
  • 更新 composer.json
  • 升级到 PSR-4
  • 在导出 CSV 时添加参数换行符、分隔符、包围符和转义符
  • 当将 XML 转换为数组时,将 @attributes 转换为 attribute
  • 在导出 XML 时添加参数编码和格式化
  • JSON 解析修复(不是仅将第一层转换为数组,而是使用关联数组参数 true,以便所有层都将解码为数组结构)
  • 添加对 Laravel 5 的支持
  • 为 Laravel 5 添加包发现
  • 为 CSV 添加分隔符支持

格式化包

一个格式化包,可以帮助您轻松地在各种格式之间进行转换,如 XML、JSON、CSV 等...

目标

该库的目标是允许将一种数据格式转换为另一种格式。请参阅解析器和格式以查看支持的输入/输出格式。

安装

通过命令行

composer require SoapBox/laravel-formatter

通过 composer.json

{
  "require": {
    "SoapBox/laravel-formatter": "2.x"
  }
}

解析器

以下都是格式化库可以读取的格式。

  • 数组
  • CSV
  • JSON
  • XML
  • YAML

格式

以下都是支持的输出格式。

  • 数组
  • CSV
  • JSON
  • XML
  • YAML

通用用法

包含格式化器

use SoapBox\Formatter\Formatter;

支持类型

Formatter::JSON; //json
Formatter::CSV;  //csv
Formatter::XML;  //xml
Formatter::ARR;  //array
Formatter::YAML; //yaml

创建您的第一个格式化器

$formatter = Formatter::make($jsonString, Formatter::JSON);
$formatter = Formatter::make($yamlString, Formatter::YAML);
$formatter = Formatter::make($array, Formatter::ARR);
...

从您的格式化器输出

$csv   = $formatter->toCsv();
$json  = $formatter->toJson();
$xml   = $formatter->toXml();
$array = $formatter->toArray();
$yaml  = $formatter->toYaml();

已弃用功能

以下功能已从库中弃用,但是您可以在您的应用程序中轻松继续使用它们

序列化数组

$serialized = serialize($formatter->toArray());

PHP 导出

$export = var_export($formatter->toArray());