salsify/json-streaming-parser

A streaming parser for JSON in PHP.

Maintainers

👁 gonzofy

Package info

github.com/salsify/jsonstreamingparser

pkg:composer/salsify/json-streaming-parser

Statistics

Installs: 7 033 758

Dependents: 20

Suggesters: 3

Stars: 779

Open Issues: 8

v8.3.1 2023-05-09 10:37 UTC

Requires

Requires (Dev)

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT c0cfac990eb4e917c71b0ad0146546f0a4da0c2f

  • Rob Gonzalez <rob.woop@salsify.com>
  • Maxim Gnatenko <mgnatenko.woop@gmail.com>
  • Max Grigorian <maxakawizard.woop@gmail.com>
  • ThePanz <thepanz.woop@gmail.com>

jsonparserstreaming


README

👁 Build Status
👁 GitHub tag
👁 Packagist
👁 Coverage Status
👁 Minimum PHP Version
👁 License

This is a simple, streaming parser for processing large JSON documents. Use it for parsing very large JSON documents to avoid loading the entire thing into memory, which is how just about every other JSON parser for PHP works.

For more details, I've written up a longer explanation of the JSON streaming parser that talks about pros and cons vs. the standard PHP JSON parser.

If you've ever used a SAX parser for XML (or even JSON) in another language, that's what this is. Except for JSON in PHP.

This package is compliant with PSR-4, PSR-1, and PSR-2. If you notice compliance oversights, please send a patch via pull request.

Installation

To install JsonStreamingParser you can either clone this repository or you can use composer

composer require salsify/json-streaming-parser

Usage

To use the JsonStreamingParser you just have to implement the \JsonStreamingParser\Listener interface. You then pass your Listener into the parser.

For example:

$stream = fopen('doc.json', 'r');
$listener = new YourListener();
try {
 $parser = new \JsonStreamingParser\Parser($stream, $listener);
 $parser->parse();
 fclose($stream);
} catch (Exception $e) {
 fclose($stream);
 throw $e;
}

That's it! Your Listener will receive events from the streaming parser as it works.

There is a complete example of this in example/example.php.

Running tests

make test

Projects using this library

JSON Collection Parser

JSON Objects

License

MIT License (c) Salsify, Inc.