byjg / anydataset-json
JSON abstraction dataset. Anydataset is an agnostic data source abstraction layer in PHP.
Fund package maintenance!
byjg
Installs: 6 835
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/byjg/anydataset-json
Requires
- php: >=8.3 <8.6
- ext-json: *
- byjg/anydataset: ^6.0
Requires (Dev)
- phpunit/phpunit: ^10.5|^11.5
- vimeo/psalm: ^5.9|^6.13
Suggests
- ext-curl: *
Provides
README
JSON abstraction dataset. Anydataset is an agnostic data source abstraction layer in PHP.
See more about Anydataset here.
Concept
The AnyDataset-Json is an abstraction layer to read a JSON data and transform it into a dataset, and you can manipulate it as a table.
Some features:
- Read a JSON file or string
- Navigate through nested JSON structures using path notation
- Define and extract fields with validation
- Create dynamic fields using closures
- Validate data types (string, int, float, bool)
- Handle required fields and default values
Basic Example
example.json:
{
"menu":{
"header":"SVG Viewer",
"items":[
{
"id":"Open",
"metadata":{
"version":"1",
"date":"NA"
}
},
{
"id":"OpenNew",
"label":"Open New",
"metadata":{
"version":"2",
"date":"2021-10-01"
}
}
]
}
}
example.php:
$json = file_get_contents('example.json'); $dataset = new \ByJG\AnyDataset\Json\JsonDataset($json); // Basic usage with field definitions $iterator = $dataset->getIterator("/menu/items") ->withFields([ \ByJG\AnyDataset\Json\JsonFieldDefinition::create("name", "id"), \ByJG\AnyDataset\Json\JsonFieldDefinition::create("version", "metadata/version") ->required() ->ofTypeString() ]); foreach ($iterator as $row) { echo $row->get('name'); // Print "Open", "OpenNew" echo $row->get('version'); // Print "1", "2" }
Features
Install
composer require "byjg/anydataset-json"
Running the Unit tests
vendor/bin/phpunit
Dependencies
flowchart TD
byjg/anydataset-json --> byjg/anydataset
byjg/anydataset-json --> ext-json
Loading