PHPackages                             lvyun66/json2php - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Parsing &amp; Serialization](/categories/parsing)
4. /
5. lvyun66/json2php

ActiveLibrary[Parsing &amp; Serialization](/categories/parsing)

lvyun66/json2php
================

Generate php files(PHP class) based on json

1.1.8(7y ago)113MITPHPPHP &gt;=7.1

Since Sep 6Pushed 7y ago1 watchersCompare

[ Source](https://github.com/lvyun66/json2php)[ Packagist](https://packagist.org/packages/lvyun66/json2php)[ Docs](https://github.com/lvyun66/json2php)[ RSS](/packages/lvyun66-json2php/feed)WikiDiscussions master Synced 3d ago

READMEChangelog (10)Dependencies (4)Versions (16)Used By (0)

json2php
========

[](#json2php)

Introduction
------------

[](#introduction)

Generate php files(PHP class) based on json

Installation
------------

[](#installation)

Via `Composer`:

```
composer require nofuck/json2php "*"
```

Usage
-----

[](#usage)

Usage is very easy. Can easily generate a PHP file:

```
$namespace = 'tests\\output\\general';
$output = TEST_ROOT . '/output/general/';
if (!is_dir($output)) {
    mkdir($output);
}

$g = new GeneratorPhpFile();
$jsonPath = TEST_ROOT . '/json/normal.json';
$g->generator(file_get_contents($jsonPath), 'Normal', $namespace, $output);
```

If you want to generate a model of Yii2:

```
$namespace = 'tests\\output\\yii2';
$output = TEST_ROOT . '/output/yii2/';
if (!is_dir($output)) {
    mkdir($output);
}

$g = new GeneratorYiiModel();
$jsonPath = TEST_ROOT . '/json/normal.json';
$g->generator(file_get_contents($jsonPath), 'Normal', $namespace, $output);
```

It’s that simple.

`generator` Method accepts four parameters:

- json
- className
- namespace
- phpOut

### Console usage

[](#console-usage)

```
12:09:05 › ./json2php -h
Description:
  Lists commands

Usage:
  list [options] [--] []

Arguments:
  namespace            The namespace name

Options:
      --raw            To output raw command list
      --format=FORMAT  The output format (txt, xml, json, or md) [default: "txt"]

Help:
  The list command lists all commands:

    php ./json2php list

  You can also display the commands for a specific namespace:

    php ./json2php list test

  You can also output the information in other formats by using the --format option:

    php ./json2php list --format=xml

  It's also possible to get raw list of commands (useful for embedding command runner):

    php ./json2php list --raw
```

There are currently two generators available, one for generating generic PHP files and the other for generating files in the Yii2 model form:

```
generator:default  [g:d] Generate a generic php object file containing properties, get and set methods
generator:yii2     [g:yii2] Generate a generic php object file containing properties, get and set methods
```

```
12:12:14 › ./json2php g:d -h
Description:
  Generate a generic php object file containing properties, get and set methods

Usage:
  generator:default [options] [--]
  g:d

Arguments:
  json                           Json file path or json string

Options:
  -t, --type[=TYPE]              Json source, file or json string, value in [file | string] [default: "file"]
  -c, --class_name[=CLASS_NAME]  Php class name, the default value is Default [default: "Generator1536207140"]
  -o, --php_out[=PHP_OUT]        Generate php file storage path, default to current directory [default: "./"]
  -h, --help                     Display this help message
  -q, --quiet                    Do not output any message
  -V, --version                  Display this application version
      --ansi                     Force ANSI output
      --no-ansi                  Disable ANSI output
  -n, --no-interaction           Do not ask any interactive question
  -ns, --namespace[=NAMESPACE]   Php namespace, please ensure the correctness of the input namespace
  -v|vv|vvv, --verbose           Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug

Help:
  This command can generate a generic php object
```

```
./json2php g:d -t string '{"name": "lvyun"}' --namespace "test\\lvyun" -c UserInfo -o .
```

Output`UserInfo.php`:

```
