Skip to main content

Python library for generating XML as a stream without building a tree in memory.

Project description

# elementflow

[![Build Status](https://travis-ci.org/isagalaev/elementflow.png)](https://travis-ci.org/isagalaev/elementflow)

Elementflow is a Python library for generating XML as a stream. Some existing
XML producing libraries (like ElementTree, lxml) build a whole XML tree in
memory and then serialize it. It might be inefficient for moderately large XML
payloads (think of a content-oriented Web service producing lots of XML data
output). Python's built-in xml.sax.saxutils.XMLGenerator is very low-level and
requires closing elements by hand.

Also, most XML libraries, to be honest, suck when dealing with namespaces.


## Usage

Basic XML generation:

```python
import elementflow
file = open('text.xml', 'w') # can be any object with .write() method

with elementflow.xml(file, u'root') as xml:
xml.element(u'item', attrs={u'key': u'value'}, text=u'text')
with xml.container(u'container', attrs={u'key': u'value'}):
xml.text(u'text')
xml.element(u'subelement', text=u'subelement text')
```

Using `with` is required to properly close container elements. The library
expects unicode strings on input and produces utf-8 encoded output (you *may*
omit those "u"s for pure ASCII strings if you want to, Python will convert
them automatically).

XML with namespaces:

```python
with elementflow.xml(file, 'root', namespaces={'': 'urn:n', 'n1': 'urn:n1'}) as xml:
xml.element('item')
with xml.container('container', namespaces={'n2': 'urn:n2'):
xml.element('n1:subelement')
xml.element('n2:subelement')
```

Elements with namespaces are defined using prefixes. You can define namespaces
at the root level and for any container. The library will check for namespace
prefixes that wasn't defined beforehand and will raise ValueError in that case.

Pretty-printing is also supported:

```python
with elementflow.xml(file, 'root', indent=True):
# ...
```

In some cases it's more convenient to have such XML producer as a Python
iterator. This is easily done by wrapping XML generation code into a generator
function:

```python
def g():
xml = elementflow.xml(elementflow.Queue(), 'root')
with xml:
for item in collection:
xml.element(...)
yield xml.file.pop()
yield xml.file.pop()
```

`elementflow.Queue()` is a temporary buffer that accepts data from an XML
generator and is cleared upon calling .pop() on it. You also might want to
yield data from the iterator only when this buffer reaches a certain size:

```python
if len(xml.file) > BUFSIZE:
yield xml.file.pop()
```

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

elementflow-0.5.tar.gz (5.4 kB view details)

Uploaded Source

Built Distribution

elementflow-0.5-py2.py3-none-any.whl (6.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file elementflow-0.5.tar.gz.

File metadata

  • Download URL: elementflow-0.5.tar.gz
  • Upload date:
  • Size: 5.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for elementflow-0.5.tar.gz
Algorithm Hash digest
SHA256 80d07550b92830e9f2ebdcda1b2106202ee9766e0e763b6489b9b2037bf9a445
MD5 6bd9c00f0412af23215be67828cb3c17
BLAKE2b-256 f7c31a91729731c2e71bce283fb081313bb5501fa9ba4f557992a3bc78e62639

See more details on using hashes here.

File details

Details for the file elementflow-0.5-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for elementflow-0.5-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 84b7cdaec6a9de075db9104fb5b1b829f8c4cb90ab86adc52c38eaa42e4f375e
MD5 384a20addabf66a44adc2ca662158895
BLAKE2b-256 37bc81c3ddb79c4e82763ca459bc6a1518093e7021262a030e59cd448e06c8b2

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