Skip to main content

'URL parser and manipulator based on the WHAT WG URL standard'

Project description

The urlib.parse module in Python does not follow the legacy RFC 3978 standard nor does it follow the newer WHATWG URL specification. It is also relatively slow.

This is ada_url, a fast standard-compliant Python library for working with URLs based on the Ada URL parser.

Installation

Install from PyPI:

pip install ada_url

Usage examples

Parsing URLs

The URL class is intended to match the one described in the WHATWG URL spec:.

>>> from ada_url import URL
>>> urlobj = URL('https://example.org/path/../file.txt')
>>> urlobj.href
'https://example.org/path/file.txt'

The parse_url function returns a dictionary of all URL elements:

>>> from ada_url import parse_url
>>> parse_url('https://user:pass@example.org:80/api?q=1#2')
{
    'href': 'https://user:pass@example.org:80/api?q=1#2',
    'username': 'user',
    'password': 'pass',
    'protocol': 'https:',
    'port': '80',
    'hostname': 'example.org',
    'host': 'example.org:80',
    'pathname': '/api',
    'search': '?q=1',
    'hash': '#2',
    'origin': 'https://example.org:80',
    'host_type': <HostType.DEFAULT: 0>,
    'scheme_type': <SchemeType.HTTPS: 2>
}

Altering URLs

Replacing URL components with the URL class:

>>> from ada_url import URL
>>> urlobj = URL('https://example.org/path/../file.txt')
>>> urlobj.host = 'example.com'
>>> urlobj.href
'https://example.com/file.txt'

Replacing URL components with the replace_url function:

>>> from ada_url import replace_url
>>> replace_url('https://example.org/path/../file.txt', host='example.com')
'https://example.com/file.txt'

Search parameters

The URLSearchParams class is intended to match the one described in the WHATWG URL spec.

>>> from ada_url import URLSearchParams
>>> obj = URLSearchParams('key1=value1&key2=value2')
>>> list(obj.items())
[('key1', 'value1'), ('key2', 'value2')]

The parse_search_params function returns a dictionary of search keys mapped to value lists:

>>> from ada_url import parse_search_params
>>> parse_search_params('key1=value1&key2=value2')
{'key1': ['value1'], 'key2': ['value2']}

Internationalized domain names

The idna class can encode and decode IDNs:

>>> from ada_url import idna
>>> idna.encode('Bücher.example')
b'xn--bcher-kva.example'
>>> idna.decode(b'xn--bcher-kva.example')
'bücher.example'

WHATWG URL compliance

This library is compliant with the WHATWG URL spec. This means, among other things, that it properly encodes IDNs and resolves paths:

>>> from ada_url import URL
>>> parsed_url = URL('https://www.GOoglé.com/./path/../path2/')
>>> parsed_url.hostname
'www.xn--googl-fsa.com'
>>> parsed_url.pathname
'/path2/'

Contrast that with the Python standard library’s urlib.parse module:

>>> from urllib.parse import urlparse
>>> parsed_url = urlparse('https://www.GOoglé.com/./path/../path2/')
>>> parsed_url.hostname
'www.googlé.com'
>>> parsed_url.path
'/./path/../path2/'

Alternative Python bindings

This package uses CFFI to call the Ada library’s functions, which has a performance cost. The alternative can_ada (Canadian Ada) package uses pybind11 to generate a Python extension module, which is more performant.

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

ada-url-1.13.0.tar.gz (215.3 kB view hashes)

Uploaded Source

Built Distributions

ada_url-1.13.0-pp39-pypy39_pp73-win_amd64.whl (1.3 MB view hashes)

Uploaded PyPy Windows x86-64

ada_url-1.13.0-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (629.3 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

ada_url-1.13.0-pp39-pypy39_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (634.4 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ARM64

ada_url-1.13.0-pp39-pypy39_pp73-macosx_10_15_x86_64.whl (586.5 kB view hashes)

Uploaded PyPy macOS 10.15+ x86-64

ada_url-1.13.0-pp38-pypy38_pp73-win_amd64.whl (1.3 MB view hashes)

Uploaded PyPy Windows x86-64

ada_url-1.13.0-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (629.3 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

ada_url-1.13.0-pp38-pypy38_pp73-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (634.4 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ ARM64

ada_url-1.13.0-pp38-pypy38_pp73-macosx_10_15_x86_64.whl (586.5 kB view hashes)

Uploaded PyPy macOS 10.15+ x86-64

ada_url-1.13.0-cp312-cp312-win_amd64.whl (1.3 MB view hashes)

Uploaded CPython 3.12 Windows x86-64

ada_url-1.13.0-cp312-cp312-musllinux_1_1_x86_64.whl (1.2 MB view hashes)

Uploaded CPython 3.12 musllinux: musl 1.1+ x86-64

ada_url-1.13.0-cp312-cp312-musllinux_1_1_aarch64.whl (1.2 MB view hashes)

Uploaded CPython 3.12 musllinux: musl 1.1+ ARM64

ada_url-1.13.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (703.9 kB view hashes)

Uploaded CPython 3.12 manylinux: glibc 2.17+ x86-64

ada_url-1.13.0-cp312-cp312-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (704.5 kB view hashes)

Uploaded CPython 3.12 manylinux: glibc 2.17+ ARM64

ada_url-1.13.0-cp312-cp312-macosx_11_0_arm64.whl (587.2 kB view hashes)

Uploaded CPython 3.12 macOS 11.0+ ARM64

ada_url-1.13.0-cp312-cp312-macosx_10_15_x86_64.whl (598.8 kB view hashes)

Uploaded CPython 3.12 macOS 10.15+ x86-64

ada_url-1.13.0-cp312-cp312-macosx_10_15_universal2.whl (973.1 kB view hashes)

Uploaded CPython 3.12 macOS 10.15+ universal2 (ARM64, x86-64)

ada_url-1.13.0-cp311-cp311-win_amd64.whl (1.3 MB view hashes)

Uploaded CPython 3.11 Windows x86-64

ada_url-1.13.0-cp311-cp311-musllinux_1_1_x86_64.whl (1.2 MB view hashes)

Uploaded CPython 3.11 musllinux: musl 1.1+ x86-64

ada_url-1.13.0-cp311-cp311-musllinux_1_1_aarch64.whl (1.2 MB view hashes)

Uploaded CPython 3.11 musllinux: musl 1.1+ ARM64

ada_url-1.13.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (702.9 kB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ x86-64

ada_url-1.13.0-cp311-cp311-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (703.7 kB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ ARM64

ada_url-1.13.0-cp311-cp311-macosx_11_0_arm64.whl (587.2 kB view hashes)

Uploaded CPython 3.11 macOS 11.0+ ARM64

ada_url-1.13.0-cp311-cp311-macosx_10_15_x86_64.whl (598.7 kB view hashes)

Uploaded CPython 3.11 macOS 10.15+ x86-64

ada_url-1.13.0-cp311-cp311-macosx_10_15_universal2.whl (973.0 kB view hashes)

Uploaded CPython 3.11 macOS 10.15+ universal2 (ARM64, x86-64)

ada_url-1.13.0-cp310-cp310-win_amd64.whl (1.3 MB view hashes)

Uploaded CPython 3.10 Windows x86-64

ada_url-1.13.0-cp310-cp310-musllinux_1_1_x86_64.whl (1.2 MB view hashes)

Uploaded CPython 3.10 musllinux: musl 1.1+ x86-64

ada_url-1.13.0-cp310-cp310-musllinux_1_1_aarch64.whl (1.2 MB view hashes)

Uploaded CPython 3.10 musllinux: musl 1.1+ ARM64

ada_url-1.13.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (702.9 kB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ x86-64

ada_url-1.13.0-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (703.7 kB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ ARM64

ada_url-1.13.0-cp310-cp310-macosx_11_0_arm64.whl (587.1 kB view hashes)

Uploaded CPython 3.10 macOS 11.0+ ARM64

ada_url-1.13.0-cp310-cp310-macosx_10_15_x86_64.whl (598.7 kB view hashes)

Uploaded CPython 3.10 macOS 10.15+ x86-64

ada_url-1.13.0-cp310-cp310-macosx_10_15_universal2.whl (972.9 kB view hashes)

Uploaded CPython 3.10 macOS 10.15+ universal2 (ARM64, x86-64)

ada_url-1.13.0-cp39-cp39-win_amd64.whl (1.3 MB view hashes)

Uploaded CPython 3.9 Windows x86-64

ada_url-1.13.0-cp39-cp39-musllinux_1_1_x86_64.whl (1.2 MB view hashes)

Uploaded CPython 3.9 musllinux: musl 1.1+ x86-64

ada_url-1.13.0-cp39-cp39-musllinux_1_1_aarch64.whl (1.2 MB view hashes)

Uploaded CPython 3.9 musllinux: musl 1.1+ ARM64

ada_url-1.13.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (702.9 kB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ x86-64

ada_url-1.13.0-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (703.7 kB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ ARM64

ada_url-1.13.0-cp39-cp39-macosx_11_0_arm64.whl (587.1 kB view hashes)

Uploaded CPython 3.9 macOS 11.0+ ARM64

ada_url-1.13.0-cp39-cp39-macosx_10_15_x86_64.whl (598.7 kB view hashes)

Uploaded CPython 3.9 macOS 10.15+ x86-64

ada_url-1.13.0-cp39-cp39-macosx_10_15_universal2.whl (973.0 kB view hashes)

Uploaded CPython 3.9 macOS 10.15+ universal2 (ARM64, x86-64)

ada_url-1.13.0-cp38-cp38-win_amd64.whl (1.3 MB view hashes)

Uploaded CPython 3.8 Windows x86-64

ada_url-1.13.0-cp38-cp38-musllinux_1_1_x86_64.whl (1.2 MB view hashes)

Uploaded CPython 3.8 musllinux: musl 1.1+ x86-64

ada_url-1.13.0-cp38-cp38-musllinux_1_1_aarch64.whl (1.2 MB view hashes)

Uploaded CPython 3.8 musllinux: musl 1.1+ ARM64

ada_url-1.13.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (703.0 kB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ x86-64

ada_url-1.13.0-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (703.8 kB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ ARM64

ada_url-1.13.0-cp38-cp38-macosx_11_0_arm64.whl (587.1 kB view hashes)

Uploaded CPython 3.8 macOS 11.0+ ARM64

ada_url-1.13.0-cp38-cp38-macosx_10_15_x86_64.whl (598.7 kB view hashes)

Uploaded CPython 3.8 macOS 10.15+ x86-64

ada_url-1.13.0-cp38-cp38-macosx_10_15_universal2.whl (972.9 kB view hashes)

Uploaded CPython 3.8 macOS 10.15+ universal2 (ARM64, x86-64)

Supported by

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