boxblinkracer / xpatharray
XPath Access for Arrays
Installs: 12 624
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 0
Open Issues: 0
Requires
- php: >=7.0
Requires (Dev)
- phpunit/phpunit: ^7.2
This package is not auto-updated.
Last update: 2025-01-05 07:29:26 UTC
README
Why XPathArrays instead of Arrays?
...small and simple, but still powerful...
If you use basic Arrays in PHP you are familiar with the array_key_exists
function.
And yes, this does really blow up your code if you have multiple levels within your array.
If you check for existing keys, the only thing you get is a PHP Notice Error
, and that obviously doesn't
result in an Exception.
With XPathArray you get the following:
- Easy XPath Selection in multiple levels, e.g. "/customer/address/street"
- Real XPathKeyNotFound Exceptions instead of PHP Notices
- Default Values for missing keys or values
- ...and a more lightweight code... :)
Installation
This package uses Composer, please checkout the composer website for more information.
The following command will install xpatharray
into your project.
It will also add a new entry in your composer.json
and update the composer.lock
as well.
$ composer require boxblinkracer/xpatharray
This package follows the PSR-4 convention names for its classes, which means you can easily integrate
xpatharray
classes loading in your own autoloader.
What now?
Here are a few examples what to do with XPathArray objects.
With Exceptions
In the first example, we access the content of our customer array using XPath syntax.
If a key is not found, we will get a XPathNotFoundException
.
This is perfect, if you want to simply use and validate your structure at once.
<?php //... $customer = array(...) # xpath array with / as our delimiter $xCustomer = new XPathArray('/', $customer); # object/array access with XPathNotFoundException /** @var array @address */ $address = $xCustomer->get('/address'); # multi level access $phoneMobile = $xCustomer->get('/contact/phone/mobile'); # type safe access with internal conversion $street = $xCustomer->getString('/street'); $streetNumber = $xCustomer->getInt('/streetNr'); $isCompany = $xCustomer->getBool('/isCompany'); $customerRevenue = $xCustomer->getFloat('/revenue/total');
Without Exceptions
In the next example, we want to access the same keys, but we do not want to get any exceptions. So we just provide a default value, that will be returned if the key is either NULL or has not been found at all.
This is perfect, if you want to work with optional nodes within your array.
<?php //... $customer = array(...) # xpath array with / as our delimiter $xCustomer = new XPathArray('/', $customer); # multi level access $phoneMobile = $xCustomer->get('/contact/phone/mobile', '-'); # type safe access with internal conversion $street = $xCustomer->getString('/street', '-'); $streetNumber = $xCustomer->getInt('/streetNr', 0); $isCompany = $xCustomer->getBool('/isCompany', false); $customerRevenue = $xCustomer->getFloat('/revenue/total', 0.0);
Copying / License
This repository is distributed under the MIT License (MIT). You can find the whole license text in the LICENSE file.