Skip to main content

Python bindings for the Uppsala XML library

Project description

pyuppsala

Python bindings for the Uppsala XML library -- a zero-dependency, pure-Rust implementation of XML 1.0, Namespaces, XPath 1.0, and XSD validation.

pyuppsala gives you a fast, correct, and memory-safe XML toolkit from Python with no C dependencies to compile and no transitive native libraries to audit.

Features

  • XML 1.0 parsing with full well-formedness checking
  • Namespace-aware DOM with tree mutation (create, append, insert, remove, detach)
  • XPath 1.0 evaluation (all axes, functions, predicates)
  • XSD validation (structures + datatypes, 40+ built-in types, facets, complex types)
  • XSD regex pattern matching (Unicode categories, blocks, character class subtraction)
  • Imperative XML builder (XmlWriter) for constructing output without a DOM
  • Serialization with pretty-printing, compact output, and streaming to files
  • Automatic encoding detection for UTF-8 and UTF-16 (LE/BE)

Installation

python3 -m pip install pyuppsala

Or with uv:

uv add pyuppsala

Wheels are compiled from Rust via maturin. Python 3.10+ is required.

Quick start

Parse and query

from pyuppsala import Document, XPathEvaluator

doc = Document("<bookstore><book><title>Moby Dick</title></book></bookstore>")
doc.prepare_xpath()

xpath = XPathEvaluator()
title = xpath.evaluate(doc, "string(//title)")
print(title)  # "Moby Dick"

Build XML

from pyuppsala import XmlWriter

w = XmlWriter()
w.write_declaration()
w.start_element("catalog", [("xmlns", "urn:example")])
w.start_element("item", [("id", "1")])
w.text("Widget")
w.end_element("item")
w.end_element("catalog")
print(w.to_string())

Validate against an XSD schema

from pyuppsala import XsdValidator

schema = """\
<?xml version="1.0"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
  <xs:element name="greeting" type="xs:string"/>
</xs:schema>
"""

validator = XsdValidator(schema)
print(validator.is_valid_str("<greeting>Hello!</greeting>"))  # True
print(validator.is_valid_str("<greeting><bad/></greeting>"))  # False

Mutate the DOM

from pyuppsala import Document

doc = Document("<root><a/></root>")
root = doc.document_element
b = doc.create_element("b")
doc.append_child(root, b)
print(doc.to_xml())  # <root><a/><b/></root>

XSD regex

from pyuppsala import XsdRegex

regex = XsdRegex(r"[0-9]{5}")
print(regex.is_match("12345"))  # True
print(regex.is_match("abcde"))  # False

API overview

Class / function Purpose
Document(xml) Parse XML string into a DOM
Document.from_bytes(data) Parse XML bytes (auto-detects UTF-8/UTF-16)
Document.empty() Create an empty document for building from scratch
Node A handle to a node in the document tree
QName A qualified XML name (local name + optional namespace + prefix)
Attribute An XML attribute (name + value)
XPathEvaluator Evaluate XPath 1.0 expressions
XsdValidator(schema) Validate documents against an XSD schema
XmlWriter Imperative XML builder (no DOM needed)
XsdRegex(pattern) XSD regular expression pattern matcher
parse(xml) Module-level shorthand for Document(xml)
parse_bytes(data) Module-level shorthand for Document.from_bytes(data)

Exceptions

Exception Raised when
XmlParseError XML is syntactically malformed
XmlWellFormednessError XML violates well-formedness constraints
XmlNamespaceError Namespace prefix is undeclared or misused
XPathError XPath expression is invalid
XsdValidationError XSD schema itself is invalid

All exceptions inherit from Exception.

Type stubs

A pyuppsala.pyi file is included for full IDE auto-completion and type-checking with mypy/pyright.

Development

# Clone the repository
git clone https://github.com/kushaldas/pyuppsala.git
cd pyuppsala

# Set up the environment with uv
uv sync

# Build the native extension in development mode
uv run maturin develop

# Run the test suite
uv run pytest

# Build a release wheel
uv run maturin build --release

License

BSD-2-Clause

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

pyuppsala-0.3.1.tar.gz (68.7 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

pyuppsala-0.3.1-cp310-abi3-win_arm64.whl (580.8 kB view details)

Uploaded CPython 3.10+Windows ARM64

pyuppsala-0.3.1-cp310-abi3-win_amd64.whl (607.6 kB view details)

Uploaded CPython 3.10+Windows x86-64

pyuppsala-0.3.1-cp310-abi3-manylinux_2_28_x86_64.whl (688.6 kB view details)

Uploaded CPython 3.10+manylinux: glibc 2.28+ x86-64

pyuppsala-0.3.1-cp310-abi3-macosx_11_0_arm64.whl (624.9 kB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

File details

Details for the file pyuppsala-0.3.1.tar.gz.

File metadata

  • Download URL: pyuppsala-0.3.1.tar.gz
  • Upload date:
  • Size: 68.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pyuppsala-0.3.1.tar.gz
Algorithm Hash digest
SHA256 5d466f01ceb84b96454fe4dde967164e74e952b2fe96490bf8adbd5cdb0cbd7e
MD5 cab7426d24a73e2a0130adb8d56ad96a
BLAKE2b-256 1833603614df7d89a9b13c6034654fc01499950b9c81eedeaaee0d139cd96310

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyuppsala-0.3.1.tar.gz:

Publisher: release.yml on kushaldas/pyuppsala

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pyuppsala-0.3.1-cp310-abi3-win_arm64.whl.

File metadata

  • Download URL: pyuppsala-0.3.1-cp310-abi3-win_arm64.whl
  • Upload date:
  • Size: 580.8 kB
  • Tags: CPython 3.10+, Windows ARM64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pyuppsala-0.3.1-cp310-abi3-win_arm64.whl
Algorithm Hash digest
SHA256 4307f4007e387812ba622e10c727314a6034da9c5ad1b9098316f8b1e65b4a01
MD5 3c852559633ffa1e021ea290475cd329
BLAKE2b-256 28c40a310f9aebe12fee6c1d0059c2cf51f0ff5f3945d95a40d2505e944d66e0

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyuppsala-0.3.1-cp310-abi3-win_arm64.whl:

Publisher: release.yml on kushaldas/pyuppsala

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pyuppsala-0.3.1-cp310-abi3-win_amd64.whl.

File metadata

  • Download URL: pyuppsala-0.3.1-cp310-abi3-win_amd64.whl
  • Upload date:
  • Size: 607.6 kB
  • Tags: CPython 3.10+, Windows x86-64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pyuppsala-0.3.1-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 3181aacf5a1683ee9dd2109f2e0e84da9e1eead40719d1814dae2f797ae528f8
MD5 694ad851a15e579dccc502e37a304c65
BLAKE2b-256 ac65b05a5e396b29c2986778eafb05d91399742b9f6cb1ccc059aa8fb25c49ee

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyuppsala-0.3.1-cp310-abi3-win_amd64.whl:

Publisher: release.yml on kushaldas/pyuppsala

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pyuppsala-0.3.1-cp310-abi3-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for pyuppsala-0.3.1-cp310-abi3-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 11b4bdbb7daa7b29816e657d8f0066a27de9a302a3e7453e776f44140a899b4c
MD5 24ca2e0323d8018557e1a3b69172c8c2
BLAKE2b-256 4cb2d11114befa1bb9dd1bc3895d615a9e9b5ea879b626835cafca4d335108e2

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyuppsala-0.3.1-cp310-abi3-manylinux_2_28_x86_64.whl:

Publisher: release.yml on kushaldas/pyuppsala

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pyuppsala-0.3.1-cp310-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for pyuppsala-0.3.1-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 0c02d6e5e1547be35419d5b8e6a2c55b209a1a5d5c8b5482a6c494390a5bc131
MD5 b54786ab1089790e726000b32a52379d
BLAKE2b-256 1865f7c30a627f127e91b8924c164cea29823efb9501d809d10099d3d89757f4

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyuppsala-0.3.1-cp310-abi3-macosx_11_0_arm64.whl:

Publisher: release.yml on kushaldas/pyuppsala

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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