Skip to main content

Provides an abstraction to lxml's XPath and XSLT functionality in a manner resembling django database models

Project description

https://travis-ci.org/theatlantic/django-xml.svg?branch=master

django-xml is a python module which provides an abstraction to lxml’s XPath and XSLT functionality in a manner resembling django database models.

Note

  • Version 2.0 drops support for Django < 1.11

  • Version 2.0.1 drops support for Python 3.4

  • Version 3.0 will drop support for Python < 3.5

Installation

To install the latest stable release of django-xml, use pip or easy_install

pip install django-xml
easy_install django-xml

For the latest development version, install from source with pip:

pip install -e git+git://github.com/theatlantic/django-xml#egg=django-xml

If the source is already checked out, install via setuptools:

python setup.py develop

Example

import math
from djxml import xmlmodels

class NumbersExample(xmlmodels.XmlModel):

    class Meta:
        extension_ns_uri = "urn:local:number-functions"
        namespaces = {"fn": extension_ns_uri,}

    all_numbers  = xmlmodels.XPathIntegerListField("//num")
    even_numbers = xmlmodels.XPathIntegerListField("//num[fn:is_even(.)]")
    sqrt_numbers = xmlmodels.XPathFloatListField("fn:sqrt(//num)")

    @xmlmodels.lxml_extension
    def is_even(self, context, number_nodes):
        numbers = [getattr(n, 'text', n) for n in number_nodes]
        return all([bool(int(num) % 2 == 0) for num in numbers])

    @xmlmodels.lxml_extension
    def sqrt(self, context, number_nodes):
        sqrts = []
        for number_node in number_nodes:
            number = getattr(number_node, 'text', number_node)
            sqrts.append(repr(math.sqrt(int(number))))
        return sqrts

def main():
    numbers_xml = u"""
    <numbers>
        <num>1</num>
        <num>2</num>
        <num>3</num>
        <num>4</num>
        <num>5</num>
        <num>6</num>
        <num>7</num>
    </numbers>"""

    example = NumbersExample.create_from_string(numbers_xml)

    print "all_numbers  = %r" % example.all_numbers
    print "even_numbers = %r" % example.even_numbers
    print "sqrt_numbers = [%s]" % ', '.join(['%.3f' % n for n in example.sqrt_numbers])
    # all_numbers  = [1, 2, 3, 4, 5, 6, 7]
    # even_numbers = [2, 4, 6]
    # sqrt_numbers = [1.000, 1.414, 1.732, 2.000, 2.236, 2.449, 2.646]

if __name__ == '__main__':
    main()

Advanced Example

An example of django-xml usage which includes XsltField and @lxml_extension methods can be found here.

API Documentation

Read API documentation on github

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

django-xml-2.0.2.tar.gz (24.7 kB view details)

Uploaded Source

Built Distribution

django_xml-2.0.2-py2.py3-none-any.whl (28.8 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file django-xml-2.0.2.tar.gz.

File metadata

  • Download URL: django-xml-2.0.2.tar.gz
  • Upload date:
  • Size: 24.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.3

File hashes

Hashes for django-xml-2.0.2.tar.gz
Algorithm Hash digest
SHA256 379ed8b8434e79d545d2a59b9156300e304b43aa2583a3db926099ac2c70ad60
MD5 c6cc259783b4b512e6bff4adfe3161c2
BLAKE2b-256 777a6da4d3c6e2ad0ab4d5ad77183baf0646a035d1fa8435c46b051efbc57b32

See more details on using hashes here.

File details

Details for the file django_xml-2.0.2-py2.py3-none-any.whl.

File metadata

  • Download URL: django_xml-2.0.2-py2.py3-none-any.whl
  • Upload date:
  • Size: 28.8 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.3

File hashes

Hashes for django_xml-2.0.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 9f252ef17dfd14cfcae2d7bd14e0503377469268161363ab93d9b81493bf179b
MD5 6d8f5148e3f188892dea606006d1d124
BLAKE2b-256 2bd18f1a50018fa3525773a26d62ff75722e590a9089faf17d9aac3ee40010df

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