Lxml

Latest version: v5.3.1

Safety actively analyzes 723683 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 9 of 28

3.8.0

Not secure
==================

Features added
--------------

* ``ElementTree.write()`` has a new option ``doctype`` that writes out a
doctype string before the serialisation, in the same way as ``tostring()``.

* GH220: ``xmlfile`` allows switching output methods at an element level.
Patch by Burak Arslan.

* LP1595781, GH240: added a PyCapsule Python API and C-level API for
passing externally generated libxml2 documents into lxml.

* GH244: error log entries have a new property ``path`` with an XPath
expression (if known, None otherwise) that points to the tree element
responsible for the error. Patch by Bob Kline.

* The namespace prefix mapping that can be used in ElementPath now injects
a default namespace when passing a None prefix.

Bugs fixed
----------

* GH238: Character escapes were not hex-encoded in the ``xmlfile`` serialiser.
Patch by matejcik.

* GH229: fix for externally created XML documents. Patch by Theodore Dubois.

* LP1665241, GH228: Form data handling in lxml.html no longer strips the
option values specified in form attributes but only the text values.
Patch by Ashish Kulkarni.

* LP1551797: revert previous fix for XSLT error logging as it breaks
multi-threaded XSLT processing.

* LP1673355, GH233: ``fromstring()`` html5parser failed to parse byte strings.

Other changes
-------------

* The previously undocumented ``docstring`` option in ``ElementTree.write()``
produces a deprecation warning and will eventually be removed.

3.7.4

==================

Bugs fixed
----------

* LP1551797: revert previous fix for XSLT error logging as it breaks
multi-threaded XSLT processing.

* LP1673355, GH233: ``fromstring()`` html5parser failed to parse byte strings.

3.7.3

Not secure
==================

Bugs fixed
----------

* GH218 was ineffective in Python 3.

* GH222: ``lxml.html.submit_form()`` failed in Python 3.
Patch by Jakub Wilk.

3.7.2

Not secure
==================

* GH220: ``xmlfile`` allows switching output methods at an element level.
Patch by Burak Arslan.

Bugs fixed
----------

* Work around installation problems in recent Python 2.7 versions
due to FTP download failures.

* GH219: ``xmlfile.element()`` was not properly quoting attribute values.
Patch by Burak Arslan.

* GH218: ``xmlfile.element()`` was not properly escaping text content of
script/style tags. Patch by Burak Arslan.

3.7.1

Not secure
==================

* No source changes, issued only to solve problems with the
binary packages released for 3.7.0.

3.7.0

Not secure
==================

Features added
--------------

* GH217: ``XMLSyntaxError`` now behaves more like its ``SyntaxError``
baseclass. Patch by Philipp A.

* GH216: ``HTMLParser()`` now supports the same ``collect_ids`` parameter
as ``XMLParser()``. Patch by Burak Arslan.

* GH210: Allow specifying a serialisation method in ``xmlfile.write()``.
Patch by Burak Arslan.

* GH203: New option ``default_doctype`` in ``HTMLParser`` that allows
disabling the automatic doctype creation. Patch by Shadab Zafar.

* GH201: Calling the method ``.set('attrname')`` without value argument
(or ``None``) on HTML elements creates an attribute without value that
serialises like ``<div attrname></div>``. Patch by Daniel Holth.

* GH197: Ignore form input fields in ``form_values()`` when they are
marked as ``disabled`` in HTML. Patch by Kristian Klemon.

Bugs fixed
----------

* GH206: File name and line number were missing from XSLT error messages.
Patch by Marcus Brinkmann.

Other changes
-------------

* Log entries no longer allow anything but plain string objects as message text
and file name.

* ``zlib`` is included in the list of statically built libraries.

Page 9 of 28

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.