Skip to main content

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 subversion repository at http://codespeak.net/svn/lxml/trunk . Running easy_install lxml==dev will install it from http://codespeak.net/svn/lxml/trunk#egg=lxml-dev

After an official release of a new stable series, bug fixes may become available at http://codespeak.net/svn/lxml/branch/lxml-2.2 . Running easy_install lxml==2.2bugfix will install the unreleased branch state from http://codespeak.net/svn/lxml/branch/lxml-2.2#egg=lxml-2.2bugfix as soon as a maintenance branch has been established.

2.2.3 (2009-10-30)

Features added

Bugs fixed

  • The resolve_entities option did not work in the incremental feed parser.

  • Looking up and deleting attributes without a namespace could hit a namespaced attribute of the same name instead.

  • Late errors during calls to SubElement() (e.g. attribute related ones) could leave a partially initialised element in the tree.

  • Modifying trees that contain parsed entity references could result in an infinite loop.

  • ObjectifiedElement.__setattr__ created an empty-string child element when the attribute value was rejected as a non-unicode/non-ascii string

  • Syntax errors in lxml.cssselect could result in misleading error messages.

  • Invalid syntax in CSS expressions could lead to an infinite loop in the parser of lxml.cssselect.

  • CSS special character escapes were not properly handled in lxml.cssselect.

  • CSS Unicode escapes were not properly decoded in lxml.cssselect.

  • Select options in HTML forms that had no explicit value attribute were not handled correctly. The HTML standard dictates that their value is defined by their text content. This is now supported by lxml.html.

  • XPath raised a TypeError when finding CDATA sections. This is now fully supported.

  • Calling help(lxml.objectify) didn’t work at the prompt.

  • The ElementMaker in lxml.objectify no longer defines the default namespaces when annotation is disabled.

  • Feed parser failed to honour the ‘recover’ option on parse errors.

  • Diverting the error logging to Python’s logging system was broken.

Other changes

Release history Release notifications | RSS feed

Download files

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

Source Distribution

lxml-2.2.3.tar.gz (3.0 MB view details)

Uploaded Source

File details

Details for the file lxml-2.2.3.tar.gz.

File metadata

  • Download URL: lxml-2.2.3.tar.gz
  • Upload date:
  • Size: 3.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for lxml-2.2.3.tar.gz
Algorithm Hash digest
SHA256 3df975ffbf71825aceda5245b1696001dd319353d1dce28b9f3bc7458f2e6433
MD5 0b3fcd56909273b3db864133475449dc
BLAKE2b-256 796eea42a78e86afe56444d8ab1f84bb7afb2ce3239799d4748ce857f702b2dc

See more details on using hashes here.

Supported by

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