Skip to main content

XPath 1.0/2.0 parsers and selectors for ElementTree.

Project description

The proposal of this package is to provide XPath 1.0 and 2.0 selectors for Python’s ElementTree XML data structures, both for the standard ElementTree library and for the lxml.etree library.

For lxml.etree this package can be useful for providing XPath 2.0 selectors, because lxml.etree already has it’s own implementation of XPath 1.0.

The XPath 2.0 functions implementation not completed yet, due to wide number of functions that this language provides. If you want you can contribute to add an unimplemented function see the section below.

Installation and usage

You can install the package with pip in a Python 2.7 or Python 3.3+ environment:

pip install elementpath

For using it import the package and apply the selectors on ElementTree nodes:

>>> import elementpath
>>> from xml.etree import ElementTree
>>> root = ElementTree.XML('<A><B1/><B2><C1/><C2/><C3/></B2></A>')
>>> elementpath.select(root, '/A/B2/*')
[<Element 'C1' at ...>, <Element 'C2' at ...>, <Element 'C3' at ...>]

The select API provides the standard XPath result format that is a list or an elementary datatype’s value. If you want only to iterate over results you can use the generator function iter_select that accepts the same arguments of select.

The selectors API works also using XML data trees based on the lxml.etree library:

>>> import elementpath
>>> import lxml.etree as etree
>>> root = etree.XML('<A><B1/><B2><C1/><C2/><C3/></B2></A>')
>>> elementpath.select(root, '/A/B2/*')
[<Element C1 at ...>, <Element C2 at ...>, <Element C3 at ...>]

When you need to apply the same XPath expression to several XML data you can also use the Selector class, creating an instance and then using it to apply the path on distinct XML data:

>>> import elementpath
>>> import lxml.etree as etree
>>> selector = elementpath.Selector('/A/*/*')
>>> root = etree.XML('<A><B1/><B2><C1/><C2/><C3/></B2></A>')
>>> selector.select(root)
[<Element C1 at ...>, <Element C2 at ...>, <Element C3 at ...>]
>>> root = etree.XML('<A><B1><C0/></B1><B2><C1/><C2/><C3/></B2></A>')
>>> selector.select(root)
[<Element C0 at ...>, <Element C1 at ...>, <Element C2 at ...>, <Element C3 at ...>]

Public API classes and functions are described into the elementpath manual on the “Read the Docs” site.

Contributing

You can contribute to this package reporting bugs, using the issue tracker or by a pull request. In case you open an issue please try to provide a test or test data for reproducing the wrong behaviour. The provided testing code shall be added to the tests of the package.

The XPath parsers are based on an implementation of the Pratt’s Top Down Operator Precedence parser. The implemented parser includes some lookup-ahead features, helpers for registering tokens and for extending language implementations. Also the token class has been generalized using a MutableSequence as base class. See tdop_parser.py for the basic internal classes and xpath1_parser.py for extensions and for a basic usage of the parser.

If you like you can use the basic parser and tokens provided by the tdop_parser.py module to implement other types of parsers (I think it could be also a funny exercise!).

License

This software is distributed under the terms of the MIT License. See the file ‘LICENSE’ in the root directory of the present distribution, or http://opensource.org/licenses/MIT.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

elementpath-1.0.10.tar.gz (30.8 kB view details)

Uploaded Source

Built Distribution

elementpath-1.0.10-py2.py3-none-any.whl (43.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file elementpath-1.0.10.tar.gz.

File metadata

File hashes

Hashes for elementpath-1.0.10.tar.gz
Algorithm Hash digest
SHA256 5d6c4fe2bca95181fa83a9bac4b0848876f2785fc220cac6804f899d52891b92
MD5 57f637abebe03e11f15b912d08db0c36
BLAKE2b-256 113e83b378c49e1e9401c2703c57d4dc80a177dd40af40eb2b43e98c44881b87

See more details on using hashes here.

File details

Details for the file elementpath-1.0.10-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for elementpath-1.0.10-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 06cb6892f89197dd4cd54bd59476e3356cb352a4b5cea7f1c34c281c3688f721
MD5 121f7f385c8a991b4e1a5222adcbe5a7
BLAKE2b-256 2f4fcc9fe67c24eb9a1ef424ce18f8c294b7689877c7a28e75861095bf5ca949

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page