Skip to main content
Help us improve PyPI by participating in user testing. All experience levels needed!

Powerful and Pythonic XML processing library combining libxml2/libxslt with the ElementTree API.

Project description

lxml is a Pythonic, mature binding for the libxml2 and libxslt libraries. It provides safe and convenient access to these libraries using the ElementTree API.

It extends the ElementTree API significantly to offer support for XPath, RelaxNG, XML Schema, XSLT, C14N and much more.

To contact the project, go to the project home page or see our bug tracker at https://launchpad.net/lxml

In case you want to use the current in-development version of lxml, you can get it from the github repository at https://github.com/lxml/lxml . Note that this requires Cython to build the sources, see the build instructions on the project home page. To the same end, running easy_install lxml==dev will install lxml from https://github.com/lxml/lxml/tarball/master#egg=lxml-dev if you have an appropriate version of Cython installed.

After an official release of a new stable series, bug fixes may become available at https://github.com/lxml/lxml/tree/lxml-3.4 . Running easy_install lxml==3.4bugfix will install the unreleased branch state from https://github.com/lxml/lxml/tarball/lxml-3.4#egg=lxml-3.4bugfix as soon as a maintenance branch has been established. Note that this requires Cython to be installed at an appropriate version for the build.

3.4.0 (2014-09-10)

Features added

  • xmlfile(buffered=False) disables output buffering and flushes the content after each API operation (starting/ending element blocks or writes). A new method xf.flush() can alternatively be used to explicitly flush the output.
  • lxml.html.document_fromstring has a new option ensure_head_body=True which will add an empty head and/or body element to the result document if missing.
  • lxml.html.iterlinks now returns links inside meta refresh tags.
  • New XMLParser option collect_ids=False to disable ID hash table creation. This can substantially speed up parsing of documents with many different IDs that are not used.
  • The parser uses per-document hash tables for XML IDs. This reduces the load of the global parser dict and speeds up parsing for documents with many different IDs.
  • ElementTree.getelementpath(element) returns a structural ElementPath expression for the given element, which can be used for lookups later.
  • xmlfile() accepts a new argument close=True to close file(-like) objects after writing to them. Before, xmlfile() only closed the file if it had opened it internally.
  • Allow “bytearray” type for ASCII text input.

Bugs fixed

Other changes

  • LP#400588: decoding errors have become hard errors even in recovery mode. Previously, they could lead to an internal tree representation in a mixed encoding state, which lead to very late errors or even silently incorrect behaviour during tree traversal or serialisation.
  • Requires Python 2.6, 2.7, 3.2 or later. No longer supports Python 2.4, 2.5 and 3.1, use lxml 3.3.x for those.
  • Requires libxml2 2.7.0 or later and libxslt 1.1.23 or later, use lxml 3.3.x with older versions.

Release history Release notifications

History Node

4.2.2

History Node

4.2.1

History Node

4.2.0

History Node

4.1.1

History Node

4.1.0

History Node

4.0.0

History Node

3.8.0

History Node

3.7.3

History Node

3.7.2

History Node

3.7.1

History Node

3.7.0

History Node

3.6.4

History Node

3.6.3

History Node

3.6.2

History Node

3.6.1

History Node

3.6.0

History Node

3.5.0

History Node

3.5.0b1

History Node

3.4.4

History Node

3.4.3

History Node

3.4.2

History Node

3.4.1

This version
History Node

3.4.0

History Node

3.3.6

History Node

3.3.5

History Node

3.3.4

History Node

3.3.3

History Node

3.3.2

History Node

3.3.1

History Node

3.3.0

History Node

3.3.0beta5

History Node

3.3.0beta4

History Node

3.3.0beta3

History Node

3.3.0beta2

History Node

3.3.0beta1

History Node

3.2.5

History Node

3.2.4

History Node

3.2.3

History Node

3.2.2

History Node

3.2.1

History Node

3.2.0

History Node

3.1.2

History Node

3.1.1

History Node

3.1.0

History Node

3.1beta1

History Node

3.0.2

History Node

3.0.1

History Node

3.0

History Node

2.3.6

History Node

2.3.5

History Node

2.3.4

History Node

2.3.3

History Node

2.3.2

History Node

2.3.1

History Node

2.3

History Node

2.3beta1

History Node

2.3alpha2

History Node

2.3alpha1

History Node

2.2.8

History Node

2.2.7

History Node

2.2.6

History Node

2.2.5

History Node

2.2.4

History Node

2.2.3

History Node

2.2.2

History Node

2.2.1

History Node

2.2

History Node

2.2beta4

History Node

2.2beta3

History Node

2.2beta2

History Node

2.2beta1

History Node

2.2alpha1

History Node

2.1.5

History Node

2.1.4

History Node

2.1.3

History Node

2.1.2

History Node

2.1.1

History Node

2.1

History Node

2.1beta3

History Node

2.1beta2

History Node

2.1beta1

History Node

2.1alpha1

History Node

2.0.11

History Node

2.0.10

History Node

2.0.9

History Node

2.0.8

History Node

2.0.7

History Node

2.0.6

History Node

2.0.5

History Node

2.0.4

History Node

2.0.3

History Node

2.0.2

History Node

2.0.1

History Node

2.0

History Node

2.0beta2

History Node

2.0beta1

History Node

2.0alpha6

History Node

2.0alpha5

History Node

2.0alpha4

History Node

2.0alpha3

History Node

2.0alpha2

History Node

2.0alpha1

History Node

1.3.6

History Node

1.3.5

History Node

1.3.4

History Node

1.3.3

History Node

1.3.2

History Node

1.3.1

History Node

1.3

History Node

1.3beta

History Node

1.2.1

History Node

1.2

History Node

1.1.2

History Node

1.1.1

History Node

1.1

History Node

1.1beta

History Node

1.1alpha

History Node

1.0.4

History Node

1.0.3

History Node

1.0.2

History Node

1.0.1

History Node

1.0

History Node

1.0.beta

History Node

0.9.2

History Node

0.9.1

History Node

0.9

Download files

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

Filename, size & hash SHA256 hash help File type Python version Upload date
lxml-3.4.0-cp26-none-win32.whl (3.0 MB) Copy SHA256 hash SHA256 Wheel 2.6 Oct 8, 2014
lxml-3.4.0-cp26-none-win_amd64.whl (3.3 MB) Copy SHA256 hash SHA256 Wheel 2.6 Oct 8, 2014
lxml-3.4.0-cp27-none-win32.whl (3.0 MB) Copy SHA256 hash SHA256 Wheel 2.7 Oct 8, 2014
lxml-3.4.0-cp27-none-win_amd64.whl (3.3 MB) Copy SHA256 hash SHA256 Wheel 2.7 Oct 8, 2014
lxml-3.4.0-cp32-none-win32.whl (3.0 MB) Copy SHA256 hash SHA256 Wheel 3.2 Oct 8, 2014
lxml-3.4.0.tar.gz (3.5 MB) Copy SHA256 hash SHA256 Source None Sep 10, 2014
lxml-3.4.0.win32-py2.6.exe (3.2 MB) Copy SHA256 hash SHA256 Windows Installer 2.6 Sep 10, 2014
lxml-3.4.0.win32-py2.7.exe (3.2 MB) Copy SHA256 hash SHA256 Windows Installer 2.7 Sep 10, 2014
lxml-3.4.0.win32-py3.2.exe (3.2 MB) Copy SHA256 hash SHA256 Windows Installer 3.2 Sep 10, 2014
lxml-3.4.0.win32-py3.3.exe (3.2 MB) Copy SHA256 hash SHA256 Windows Installer 3.3 Jun 8, 2016
lxml-3.4.0.win32-py3.4.exe (3.2 MB) Copy SHA256 hash SHA256 Windows Installer 3.4 Jun 8, 2016
lxml-3.4.0.win-amd64-py2.6.exe (3.5 MB) Copy SHA256 hash SHA256 Windows Installer 2.6 Sep 10, 2014
lxml-3.4.0.win-amd64-py2.7.exe (3.5 MB) Copy SHA256 hash SHA256 Windows Installer 2.7 Sep 10, 2014
lxml-3.4.0.win-amd64-py3.2.exe (3.5 MB) Copy SHA256 hash SHA256 Windows Installer 3.2 Jun 8, 2016
lxml-3.4.0.win-amd64-py3.3.exe (3.5 MB) Copy SHA256 hash SHA256 Windows Installer 3.3 Jun 8, 2016
lxml-3.4.0.win-amd64-py3.4.exe (3.5 MB) Copy SHA256 hash SHA256 Windows Installer 3.4 Jun 8, 2016

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging CloudAMQP CloudAMQP RabbitMQ AWS AWS Cloud computing Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page