Skip to main content

Yet another URL library

Project description

yarl

https://travis-ci.org/aio-libs/yarl.svg?branch=master https://codecov.io/gh/aio-libs/yarl/branch/master/graph/badge.svg https://badge.fury.io/py/yarl.svg https://readthedocs.org/projects/yarl/badge/?version=latest https://img.shields.io/pypi/pyversions/yarl.svg Chat on Gitter

Introduction

Url is constructed from str:

>>> from yarl import URL
>>> url = URL('https://www.python.org/~guido?arg=1#frag')
>>> url
URL('https://www.python.org/~guido?arg=1#frag')

All url parts: scheme, user, password, host, port, path, query and fragment are accessible by properties:

>>> url.scheme
'https'
>>> url.host
'www.python.org'
>>> url.path
'/~guido'
>>> url.query_string
'arg=1'
>>> url.query
<MultiDictProxy('arg': '1')>
>>> url.fragment
'frag'

All url manipulations produce a new url object:

>>> url.parent / 'downloads/source'
URL('https://www.python.org/downloads/source')

Strings passed to constructor and modification methods are automatically encoded giving canonical representation as result:

>>> url = URL('https://www.python.org/путь')
>>> url
URL('https://www.python.org/%D0%BF%D1%83%D1%82%D1%8C')

Regular properties are percent-decoded, use raw_ versions for getting encoded strings:

>>> url.path
'/путь'

>>> url.raw_path
'/%D0%BF%D1%83%D1%82%D1%8C'

Human readable representation of URL is available as .human_repr():

>>> url.human_repr()
'https://www.python.org/путь'

For full documentation please read https://yarl.readthedocs.org.

Installation

$ pip install yarl

The library is Python 3 only!

Dependencies

YARL requires multidict library.

API documentation

The documentation is located at https://yarl.readthedocs.org

Comparison with other URL libraries

  • furl (https://pypi.python.org/pypi/furl)

    The library has rich functionality but the furl object is mutable.

    I’m afraid to pass this object into foreign code: who knows if the code will modify my url in a terrible way while I just want to send URL with handy helpers for accessing URL properties.

    furl has other non-obvious tricky things but the main objection is mutability.

  • URLObject (https://pypi.python.org/pypi/URLObject)

    URLObject is immutable, that’s pretty good.

    Every URL change generates a new URL object.

    But the library doesn’t do any decode/encode transformations leaving the end user to cope with these gory details.

Source code

The project is hosted on GitHub

Please file an issue on the bug tracker if you have found a bug or have some suggestion in order to improve the library.

The library uses Travis for Continuous Integration.

Discussion list

aio-libs google group: https://groups.google.com/forum/#!forum/aio-libs

Feel free to post your questions and ideas here.

Authors and License

The yarl package is written by Andrew Svetlov.

It’s Apache 2 licensed and freely available.

CHANGES

1.2.0 (2018-04-30)

  • Forbid inheritance, replace __init__ with __new__ (#171)

  • Support PEP-561 (provide type hinting marker) (#182)

1.1.1 (2018-02-17)

  • Fix performance regression: don’t encode enmpty netloc (#170)

1.1.0 (2018-01-21)

  • Make pure Python quoter consistent with Cython version (#162)

1.0.0 (2018-01-15)

  • Use fast path if quoted string does not need requoting (#154)

  • Speed up quoting/unquoting by _Quoter and _Unquoter classes (#155)

  • Drop yarl.quote and yarl.unquote public functions (#155)

  • Add custom string writer, reuse static buffer if available (#157) Code is 50-80 times faster than Pure Python version (was 4-5 times faster)

  • Don’t recode IP zone (#144)

  • Support encoded=True in yarl.URL.build() (#158)

  • Fix updating query with multiple keys (#160)

0.18.0 (2018-01-10)

  • Fallback to IDNA 2003 if domain name is not IDNA 2008 compatible (#152)

0.17.0 (2017-12-30)

  • Use IDNA 2008 for domain name processing (#149)

0.16.0 (2017-12-07)

  • Fix raising TypeError by url.query_string() after url.with_query({}) (empty mapping) (#141)

0.15.0 (2017-11-23)

  • Add raw_path_qs attribute (#137)

0.14.2 (2017-11-14)

  • Restore strict parameter as no-op in quote/unquote

0.14.1 (2017-11-13)

  • Restore strict parameter as no-op for sake of compatibility with aiohttp 2.2

0.14.0 (2017-11-11)

  • Drop strict mode (#123)

  • Fix “ValueError: Unallowed PCT %” when there’s a “%” in the url (#124)

0.13.0 (2017-10-01)

  • Document encoded parameter (#102)

  • Support relative urls like ‘?key=value’ (#100)

  • Unsafe encoding for QS fixed. Encode ; char in value param (#104)

  • Process passwords without user names (#95)

0.12.0 (2017-06-26)

  • Properly support paths without leading slash in URL.with_path() (#90)

  • Enable type annotation checks

0.11.0 (2017-06-26)

  • Normalize path (#86)

  • Clear query and fragment parts in .with_path() (#85)

0.10.3 (2017-06-13)

  • Prevent double URL args unquoting (#83)

0.10.2 (2017-05-05)

  • Unexpected hash behaviour (#75)

0.10.1 (2017-05-03)

  • Unexpected compare behaviour (#73)

  • Do not quote or unquote + if not a query string. (#74)

0.10.0 (2017-03-14)

  • Added URL.build class method (#58)

  • Added path_qs attribute (#42)

0.9.8 (2017-02-16)

  • Do not quote “:” in path

0.9.7 (2017-02-16)

  • Load from pickle without _cache (#56)

  • Percent-encoded pluses in path variables become spaces (#59)

0.9.6 (2017-02-15)

  • Revert backward incompatible change (BaseURL)

0.9.5 (2017-02-14)

  • Fix BaseURL rich comparison support

0.9.4 (2017-02-14)

  • Use BaseURL

0.9.3 (2017-02-14)

  • Added BaseURL

0.9.2 (2017-02-08)

  • Remove debug print

0.9.1 (2017-02-07)

  • Do not lose tail chars (#45)

0.9.0 (2017-02-07)

  • Allow to quote % in non strict mode (#21)

  • Incorrect parsing of query parameters with %3B (;) inside (#34)

  • core dumps (#41)

  • tmpbuf - compiling error (#43)

  • Added URL.update_path() method

  • Added URL.update_query() method (#47)

0.8.1 (2016-12-03)

  • Fix broken aiohttp: revert back quote / unquote.

0.8.0 (2016-12-03)

  • Support more verbose error messages in .with_query() (#24)

  • Don’t percent-encode @ and : in path (#32)

  • Don’t expose yarl.quote and yarl.unquote, these functions are part of private API

0.7.1 (2016-11-18)

  • Accept not only str but all classes inherited from str also (#25)

0.7.0 (2016-11-07)

  • Accept int as value for .with_query()

0.6.0 (2016-11-07)

  • Explicitly use UTF8 encoding in setup.py (#20)

  • Properly unquote non-UTF8 strings (#19)

0.5.3 (2016-11-02)

  • Don’t use namedtuple fields but indexes on URL construction

0.5.2 (2016-11-02)

  • Inline _encode class method

0.5.1 (2016-11-02)

  • Make URL construction faster by removing extra classmethod calls

0.5.0 (2016-11-02)

  • Add cython optimization for quoting/unquoting

  • Provide binary wheels

0.4.3 (2016-09-29)

  • Fix typing stubs

0.4.2 (2016-09-29)

  • Expose quote() and unquote() as public API

0.4.1 (2016-09-28)

  • Support empty values in query (‘/path?arg’)

0.4.0 (2016-09-27)

  • Introduce relative() (#16)

0.3.2 (2016-09-27)

  • Typo fixes #15

0.3.1 (2016-09-26)

  • Support sequence of pairs as with_query() parameter

0.3.0 (2016-09-26)

  • Introduce is_default_port()

0.2.1 (2016-09-26)

0.2.0 (2016-09-18)

  • Avoid doubling slashes when joining paths (#13)

  • Appending path starting from slash is forbidden (#12)

0.1.4 (2016-09-09)

  • Add kwargs support for with_query() (#10)

0.1.3 (2016-09-07)

  • Document with_query(), with_fragment() and origin()

  • Allow None for with_query() and with_fragment()

0.1.2 (2016-09-07)

  • Fix links, tune docs theme.

0.1.1 (2016-09-06)

  • Update README, old version used obsolete API

0.1.0 (2016-09-06)

  • The library was deeply refactored, bytes are gone away but all accepted strings are encoded if needed.

0.0.1 (2016-08-30)

  • The first release.

Project details


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

yarl-1.2.0.tar.gz (157.7 kB view details)

Uploaded Source

Built Distributions

yarl-1.2.0-cp36-cp36m-win_amd64.whl (119.6 kB view details)

Uploaded CPython 3.6m Windows x86-64

yarl-1.2.0-cp36-cp36m-win32.whl (114.1 kB view details)

Uploaded CPython 3.6m Windows x86

yarl-1.2.0-cp36-cp36m-manylinux1_x86_64.whl (256.6 kB view details)

Uploaded CPython 3.6m

yarl-1.2.0-cp36-cp36m-manylinux1_i686.whl (246.8 kB view details)

Uploaded CPython 3.6m

yarl-1.2.0-cp35-cp35m-win_amd64.whl (119.1 kB view details)

Uploaded CPython 3.5m Windows x86-64

yarl-1.2.0-cp35-cp35m-win32.whl (113.7 kB view details)

Uploaded CPython 3.5m Windows x86

yarl-1.2.0-cp35-cp35m-manylinux1_x86_64.whl (252.4 kB view details)

Uploaded CPython 3.5m

yarl-1.2.0-cp35-cp35m-manylinux1_i686.whl (243.0 kB view details)

Uploaded CPython 3.5m

yarl-1.2.0-cp34-cp34m-win_amd64.whl (118.3 kB view details)

Uploaded CPython 3.4m Windows x86-64

yarl-1.2.0-cp34-cp34m-win32.whl (114.7 kB view details)

Uploaded CPython 3.4m Windows x86

yarl-1.2.0-cp34-cp34m-manylinux1_x86_64.whl (254.6 kB view details)

Uploaded CPython 3.4m

yarl-1.2.0-cp34-cp34m-manylinux1_i686.whl (244.9 kB view details)

Uploaded CPython 3.4m

File details

Details for the file yarl-1.2.0.tar.gz.

File metadata

  • Download URL: yarl-1.2.0.tar.gz
  • Upload date:
  • Size: 157.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for yarl-1.2.0.tar.gz
Algorithm Hash digest
SHA256 fbbb10276d53629c0300cfd4a2092e3bbfa9a5aa95cd49808e01c59492052077
MD5 597d8a4361567b89e338b771ad52125e
BLAKE2b-256 639f1cfd6d213ca534589f864a478573103771559c9cec14473bb09412f0d2f8

See more details on using hashes here.

File details

Details for the file yarl-1.2.0-cp36-cp36m-win_amd64.whl.

File metadata

File hashes

Hashes for yarl-1.2.0-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 cec06d4272c2ced65308daf63360daeea5061c030fe28f75e499afd735cee860
MD5 500c0239cc725533012a4cec381e3608
BLAKE2b-256 b1ffc5f685dc39e7d4a9c82ce9fe2744050df87d186be5cecbb67f42642e2369

See more details on using hashes here.

File details

Details for the file yarl-1.2.0-cp36-cp36m-win32.whl.

File metadata

File hashes

Hashes for yarl-1.2.0-cp36-cp36m-win32.whl
Algorithm Hash digest
SHA256 ce5963f2451661a435721d8907a824daea52aad6e3bee9b4104e75d19269cdae
MD5 72d138a1227e375f549f06c2dd1b2054
BLAKE2b-256 2ed4808c1ecb287e4f8c05f76146e2bdccec56372120a9a62f5ecc7b15279a9b

See more details on using hashes here.

File details

Details for the file yarl-1.2.0-cp36-cp36m-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for yarl-1.2.0-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 ac574aa2c45185e038489ff8f3bebd9269dd8327e86c72d9a7f83a1d3ad9eec4
MD5 6b56ab02d397ad00326e2f0250363bc5
BLAKE2b-256 96eed079ee9984c4a9aa29b8bf7b1c3c168cee9c288b0fb8944789fba597e5ac

See more details on using hashes here.

File details

Details for the file yarl-1.2.0-cp36-cp36m-manylinux1_i686.whl.

File metadata

File hashes

Hashes for yarl-1.2.0-cp36-cp36m-manylinux1_i686.whl
Algorithm Hash digest
SHA256 a2dda88459cfe50f4f6a225d2f51e3fffb0c3c18f4c3a3ac38d9dc054f8c37b0
MD5 c18bba908ebbde17208571a5e442b75d
BLAKE2b-256 412bbec9a4d1ecc9737dd59a358fe18adc5a408ab6c0250a16f8be2ff0ad20a9

See more details on using hashes here.

File details

Details for the file yarl-1.2.0-cp35-cp35m-win_amd64.whl.

File metadata

File hashes

Hashes for yarl-1.2.0-cp35-cp35m-win_amd64.whl
Algorithm Hash digest
SHA256 48f3807855b69414a41e70908e502d6dbf563e3eca22f73d1344aad9270a4ff9
MD5 6e4ddaac6015f31244a8304ccbe1c0d2
BLAKE2b-256 928f08069c997ea5d65eaf2ce2b16865895b9bb13669be8db5d5709ca8bdc6cf

See more details on using hashes here.

File details

Details for the file yarl-1.2.0-cp35-cp35m-win32.whl.

File metadata

File hashes

Hashes for yarl-1.2.0-cp35-cp35m-win32.whl
Algorithm Hash digest
SHA256 32a52453fc20153e34d2cf99f1a2f4c3d144e320896f1f89b5ee89bb41e877be
MD5 4e1eb556e515baa003e3795a734d4ebd
BLAKE2b-256 972ce8c2eb037f46509493e9a6123bea3a96a24af8ef14fa66fb350aaf40313f

See more details on using hashes here.

File details

Details for the file yarl-1.2.0-cp35-cp35m-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for yarl-1.2.0-cp35-cp35m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 3278209d78d534d59ee44f595e54ee4d3a164fa77319ffbd418b1978edf71748
MD5 f5aa83e14a3645190430e278ca1f3353
BLAKE2b-256 237d41beef3b35c1836079fde8408aebfb3c0a24c6bf2e66078d351fc4cfa1ff

See more details on using hashes here.

File details

Details for the file yarl-1.2.0-cp35-cp35m-manylinux1_i686.whl.

File metadata

File hashes

Hashes for yarl-1.2.0-cp35-cp35m-manylinux1_i686.whl
Algorithm Hash digest
SHA256 843c90c7a2756c033e9bb4464f789e21bc33f561c1e6c0ef7569f452b33a761a
MD5 60dcd5ff87bd8a300ddb65e98a792757
BLAKE2b-256 7c1bbc22313cb72359411d78806fc2502f11f191a64fcccf2b6d64527aa3d954

See more details on using hashes here.

File details

Details for the file yarl-1.2.0-cp34-cp34m-win_amd64.whl.

File metadata

File hashes

Hashes for yarl-1.2.0-cp34-cp34m-win_amd64.whl
Algorithm Hash digest
SHA256 ceae77215870ecaba555b2e74dd308de9abe6d44b0eecafae6ecef4a14e289f8
MD5 ceeb6240e96d9f9012c21c50a1197f6f
BLAKE2b-256 e670655185b1656f3e03a56e12b202b16e7823886ab9305d97e8c4377181c022

See more details on using hashes here.

File details

Details for the file yarl-1.2.0-cp34-cp34m-win32.whl.

File metadata

File hashes

Hashes for yarl-1.2.0-cp34-cp34m-win32.whl
Algorithm Hash digest
SHA256 8765ebd034d0dc812a311b31251dffb434c753fc7124487912a5bca7baeb5c9b
MD5 2df1b68e7e9651bcee687b6d96eee523
BLAKE2b-256 867f865cc2e65a3029a6131c0f6beaf47404e353037415aeb91adf8aa3f399d8

See more details on using hashes here.

File details

Details for the file yarl-1.2.0-cp34-cp34m-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for yarl-1.2.0-cp34-cp34m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 4c2d780cb0b669bf027da57a0834d4968ed55c89f1593cfd11be8108bff699e2
MD5 4772ea35a5c741ab6931826ed9476fb8
BLAKE2b-256 51f2d23b6dc15741de83f14dafeeb0bcb3fd50d4e11544b6ebb336a68a8f0f14

See more details on using hashes here.

File details

Details for the file yarl-1.2.0-cp34-cp34m-manylinux1_i686.whl.

File metadata

File hashes

Hashes for yarl-1.2.0-cp34-cp34m-manylinux1_i686.whl
Algorithm Hash digest
SHA256 ee506bc321b455b4a410724ec9c0ad4940932553523c6e7b69f0155269793734
MD5 49a7e9c474ec56599f281e7332809148
BLAKE2b-256 9732e54a7fb20dd78a702eb6c866f9d69fd0c98640277b526615586af17a924a

See more details on using hashes here.

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