noi / querypath-format
QueryPath extension that adds extra methods for formatting node values
v1.0
2013-10-25 03:43 UTC
Requires
- php: >=5.3.0
- querypath/querypath: >=3.0.0
This package is not auto-updated.
Last update: 2024-11-19 01:33:30 UTC
README
FormatExtension is a QueryPath extension that adds the following methods:
format($callback [, $args, [, $... ]])
formatAttr($name, $callback [, $args, [, $... ]])
Installation
With Composer, run:
$ php composer.phar require noi/querypath-format "*"
Alternatively, you can edit your composer.json
manually and add the following:
{ "require": { "noi/querypath-format": "*" } }
Usage
format()
\QueryPath\DOMQuery format(callable $callback [, mixed $args [, $... ]])
A quick example:
<?php require_once '/path/to/vendor/autoload.php'; QueryPath::enable('Noi\QueryPath\FormatExtension'); $qp = qp('<?xml version="1.0"?><root><div>_apple_</div><div>_orange_</div></root>'); $qp->find('div') ->format('strtoupper') ->format('trim', '_') ->format(function ($text) { return '*' . $text . '*'; }); $qp->writeXML();
OUTPUT:
<?xml version="1.0"?> <root> <div>*APPLE*</div> <div>*ORANGE*</div> </root>
formatAttr()
\QueryPath\DOMQuery formatAttr(string $name, callable $callback [, mixed $args [, $... ]])
A quick example:
<?php require_once '/path/to/vendor/autoload.php'; QueryPath::enable('Noi\QueryPath\FormatExtension'); $qp = qp('<?xml version="1.0"?><root>' . '<item label="_apple_" total="12,345,678" />' . '<item label="_orange_" total="987,654,321" />' . '</root>'); $qp->find('item') ->formatAttr('label', 'trim', '_') ->formatAttr('total', 'str_replace[2]', ',', ''); $qp->find('item')->formatAttr('label', function ($value) { return ucfirst(strtolower($value)); }); $qp->writeXML();
OUTPUT:
<?xml version="1.0"?> <root> <item label="Apple" total="12345678"/> <item label="Orange" total="987654321"/> </root>
License
FormatExtension is licensed under the MIT License - see the LICENSE
file for details.