boxblinkracer/xpatharray

XPath Access for Arrays

1.0.1 2018-07-16 21:05 UTC

This package is not auto-updated.

Last update: 2025-01-05 07:29:26 UTC


README

Downloads Latest stable version PHP from Packagist GitHub stars MIT licensed

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.