A small library to parse text representations of a PHP array and return an actual PHP array.
Run composer install
to run this script (and tests) in a standalone way. Alternatively, this can be used as a dependency in another project by running composer require battye/php-array-parser "~1.0"
.
Reference the namespace at the top of your PHP files to utilise the included classes:
use battye\array_parser\parser;
use battye\array_parser\tokens;
If you notice any bugs, please raise an issue or pull request.
In both of the following examples, $result
would contain a PHP array containing the representation of the string or text file provided.
To parse a simple array is very easy:
$value = "array(0 => array('one' => 1, 'two' => 'two'));";
$result = parser::parse_simple($value);
In this case, $result
would produce the following:
array(1) {
[0] =>
array(2) {
'one' =>
int(1)
'two' =>
string(3) "two"
}
}
Regular expressions can also be used to parse complex files and extract array values:
$regex = '/\$lang\s+=\s+array_merge\(\$lang, array\((.*?)\)\);/s';
$file = __DIR__ . '/files/test_lang.php';
$result = parser::parse_regex($regex, $file);
The unit tests provide good examples of how to utilise this library and can be found in the tests/
directory. To execute the unit tests, run:
vendor/bin/simple-phpunit tests/