This library is an extremely fast and strictly typed object mapper built for modern PHP (8.2+). It seamlessly transforms data from formats like CSV, JSON, NEON, XML, YAML, arrays, and standard objects into well-structured PHP objects.
Ideal for developers who need reliable and efficient data mapping without sacrificing code quality or modern best practices.
- Mapping source data into objects
- Mapping source data with a list of elements into a list of objects
- Initialize object via constructor, properties or methods
- Map nested objects, arrays of objects
- Class mapping for interfaces or other classes
- Custom root element for starting with the source data
- Auto-casting for
float
types (eu to us decimal separator) - Target alias via Attribute for properties and methods
- Automatic data sorting for constructor parameters
null
bool
|?bool
int
|?int
float
|?float
string
|?string
array
int[]
float[]
string[]
object[]
object
|?object
enum
|?enum
optional formats are marked with an asterisk *
array
csv
json
neon
*object
public property
public getters
method toArray()
attribute SourceData('...')
xml
yaml
*
Require the bundle and its dependencies with composer:
composer require wundii/data-mapper
use Wundii\DataMapper\DataMapper;
/**
* DataConfig default settings
* - ApproachEnum::SETTER - will use the constructor to map the data
* - AccessibleEnum::PUBLIC - will use only public properties/methods
* - classMap = [] - will not map any classes
*/
$dataMapper = new DataMapper();
$testClass = $dataMapper->array($array, TestClass::class);
$testClass = $dataMapper->csv($csvFileOrContent, TestClass::class);
$testClass = $dataMapper->json($json, TestClass::class);
$testClass = $dataMapper->neon($neon, TestClass::class);
$testClass = $dataMapper->xml($xml, TestClass::class);
$testClass = $dataMapper->yaml($yaml, TestClass::class);
use Wundii\DataMapper\DataConfig;
use Wundii\DataMapper\DataMapper;
use Wundii\DataMapper\Enum\ApproachEnum;
$dataConfig = new DataConfig(
approachEnum: ApproachEnum::PROPERTY,
classMap: [
DateTimeInterface::class => DateTime::class,
],
);
$dataMapper = new DataMapper($dataConfig);
$testClass = $dataMapper->array($array, TestClass::class);
$testClass = $dataMapper->csv($csvFileOrContent, TestClass::class);
$testClass = $dataMapper->json($json, TestClass::class);
$testClass = $dataMapper->neon($neon, TestClass::class);
$testClass = $dataMapper->xml($xml, TestClass::class);
$testClass = $dataMapper->yaml($yaml, TestClass::class);