Skip to main content

Fast XML to Python (and vise versa) converter and filter. Written in C++ using Expat SAX parser

Project description

Introduction
============

nkit4py - is a nkit C++ library port to Python (see https://github.com/eye3/nkit.git).

With nkit4py module you can convert XML string to Python data and vise versa.

With XML-to-Python-data possibilities you can:
----------------------------------------------

- Simply convert XML to Python data with the same structure.
Usual Python Dict objects as well as collections.OrderedDict objects can be created.

- Convert XML to Python data with the structure, which is different from the structure
of XML source (using mapping).

- Create multiple Python structures from one XML source.

- Explicitly identify those elements and attributes in XML source that you
want to use for building Python data structures.
Thus, it's possible to filter out unnecessary XML-data.

- Explicitly define Python type of scalar (primitive) data,
fetched from XML source.
Integers, numbers, strings, datetimes and booleans are supported.

- Control progress of chunked download and parsing of big XML string

- With extra options you can tune some aspects of conversion:
- trim text data
- explicitly define white space characters for trim option
- choose unicode or string type for text data
- define special key to collect all element attributes

Conversion is carried out using SAX parser Expat, so it's fast and uses less
memory when parsing huge XML files.

Module supports not only native Expat XML encodings, but also many others
(see /deps/nkit/src/encoding/langs.inc)

With Python-data-to-XML possibilities you can:
----------------------------------------------

- Create xml string with the same structure as Python data
- Define root element name of result xml string
- Define default element name for list items
- Define encoding of result xml string
- Pretty print with custom indentation and newline characters
- Define special object key name for attributes
- Define special object key name for text
- Define which elements of result xml string must contain CDATA section
- Define precision for float numbers
- Define format for Date objects
- Define representation for *True* and *False* values
- Explicitly define order in which DICT keys will be printed to XML text


Installation
============

On Linux and Mac OS
-----------------

pip install nkit4py

On Windows
----------

Library compiles on MSVS Express version >= 2012.

For MSVS 2012:

SET VS90COMNTOOLS=%VS110COMNTOOLS%

pip install nkit4py

For MSVS 2013:

SET VS90COMNTOOLS=%VS120COMNTOOLS%

pip install nkit4py

Usage
=====

See https://github.com/eye3/nkit4py

Python version support
======================
==2.6
==2.7
>=3.3

Author
======

Boris T. Darchiev (boris.darchiev@gmail.com)

On github: https://github.com/eye3

Any feedback or pull request are welcome!

Project details


Download files

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

Source Distributions

nkit4py-2.3.5.zip (366.7 kB view details)

Uploaded Source

nkit4py-2.3.5.tar.gz (280.9 kB view details)

Uploaded Source

File details

Details for the file nkit4py-2.3.5.zip.

File metadata

  • Download URL: nkit4py-2.3.5.zip
  • Upload date:
  • Size: 366.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for nkit4py-2.3.5.zip
Algorithm Hash digest
SHA256 5dc8485c8cf590588a97013f33c506b6c865c9425ead2e567df64164646646f8
MD5 16ea1b81a1d0ae24d4bf4a155ac31c30
BLAKE2b-256 77ec9ebcc7af35736ec7bf352d06ef0756920644866974199569516f13cbec35

See more details on using hashes here.

File details

Details for the file nkit4py-2.3.5.tar.gz.

File metadata

  • Download URL: nkit4py-2.3.5.tar.gz
  • Upload date:
  • Size: 280.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for nkit4py-2.3.5.tar.gz
Algorithm Hash digest
SHA256 d2a4730eb379d8220e8acac4164fa05fc1e3d103a2d28ad5e125783cf5caef11
MD5 95cfc0da68b53c6808f02d840a3c3d53
BLAKE2b-256 747fc1d50517123c3318caf346b1e1f42b9f63bacb6894f2936d669c7b99885f

See more details on using hashes here.

Supported by

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