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.3 (2018-05-03)

  • Accept str subclasses in URL constructor (#190)

1.2.2 (2018-05-01)

  • Fix build

1.2.1 (2018-04-30)

  • Pin minimal required Python to 3.5.3 (#189)

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

This version

1.2.3

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.3.tar.gz (159.5 kB view details)

Uploaded Source

Built Distributions

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

yarl-1.2.3-cp36-cp36m-win_amd64.whl (119.7 kB view details)

Uploaded CPython 3.6mWindows x86-64

yarl-1.2.3-cp36-cp36m-win32.whl (114.2 kB view details)

Uploaded CPython 3.6mWindows x86

yarl-1.2.3-cp36-cp36m-manylinux1_x86_64.whl (252.2 kB view details)

Uploaded CPython 3.6m

yarl-1.2.3-cp36-cp36m-manylinux1_i686.whl (242.3 kB view details)

Uploaded CPython 3.6m

yarl-1.2.3-cp35-cp35m-win_amd64.whl (119.2 kB view details)

Uploaded CPython 3.5mWindows x86-64

yarl-1.2.3-cp35-cp35m-win32.whl (113.8 kB view details)

Uploaded CPython 3.5mWindows x86

yarl-1.2.3-cp35-cp35m-manylinux1_x86_64.whl (247.9 kB view details)

Uploaded CPython 3.5m

yarl-1.2.3-cp35-cp35m-manylinux1_i686.whl (238.6 kB view details)

Uploaded CPython 3.5m

File details

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

File metadata

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

File hashes

Hashes for yarl-1.2.3.tar.gz
Algorithm Hash digest
SHA256 1fc3e17ab13e46cae1a6067ad4c210d6efa378267d312ed6a47803d0e5ca0d97
MD5 c4b8d2ff886b3488baf7e1a6356f06fe
BLAKE2b-256 a99b966b8bb5760a784fb777df619f0f44029fe1bbc9d5bd0da246ca5cfc8cf3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for yarl-1.2.3-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 0d3ceda7a71d0476496a3a198081e09f2b8716793702e76e78241ca87165b751
MD5 2bb9b2a90b74add9cc6b924519ffac37
BLAKE2b-256 99fa5c84aff513edfdb9915c8f715250a39014efe4c5929f66cc4efe363ec9d0

See more details on using hashes here.

File details

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

File metadata

  • Download URL: yarl-1.2.3-cp36-cp36m-win32.whl
  • Upload date:
  • Size: 114.2 kB
  • Tags: CPython 3.6m, Windows x86
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for yarl-1.2.3-cp36-cp36m-win32.whl
Algorithm Hash digest
SHA256 80dae5e4917300cbf03954367fba72c0578da6fdaf99a1275adc310e1cdf39df
MD5 5d905b056d551bf1f47f758ad98e04ce
BLAKE2b-256 45b56e4c163369ed11d56e3690707c0e4472a3b08c9172806b24ff02ac273fe0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for yarl-1.2.3-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 b202c20dcae6305561910a0c8ff1cb9f85178ef2635ee5ce2ef1e41392a0513d
MD5 888a4358b66b6b07ed7c1e3ac461d022
BLAKE2b-256 822f9071e81bcd8775f3859c0695c4f57553bf01b0c911aaa0a7b8c561093ff6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for yarl-1.2.3-cp36-cp36m-manylinux1_i686.whl
Algorithm Hash digest
SHA256 1640294c0315fa17515b0d95f7afd76493b7cae5235bf2b395787cef11b0745d
MD5 fa7ba81d397bb2b1c202a55469305c64
BLAKE2b-256 1086098fa09158d8825fe97b8e3d137c0f825d07900d244d1a0f606e3e795b5a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for yarl-1.2.3-cp35-cp35m-win_amd64.whl
Algorithm Hash digest
SHA256 43b33a86f0ff56f8a40de648f0a9b09a12e08f8024775f9fb6eae8729af96a89
MD5 d17d8dcdfdc22831a4b22a25698ce0a5
BLAKE2b-256 1066fc378b0bdc90f55bb8c643e73f6b486a2abb4d62a2126871248ff853da2f

See more details on using hashes here.

File details

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

File metadata

  • Download URL: yarl-1.2.3-cp35-cp35m-win32.whl
  • Upload date:
  • Size: 113.8 kB
  • Tags: CPython 3.5m, Windows x86
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for yarl-1.2.3-cp35-cp35m-win32.whl
Algorithm Hash digest
SHA256 5eb6514c311003b897cc8e2e8205155bab86f92d8b7411d5b4808a6636e7f578
MD5 09a60f9d4707feb9acfa02ca9953e391
BLAKE2b-256 209a2233cb40185ca97bfad45573051005b57401210c80b90a1c7218c73c3614

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for yarl-1.2.3-cp35-cp35m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 d7c327e826d8ef05c255dec137404302f147da436182e9cb97517ccf60ecfb2e
MD5 dbd5ea6e1240d6026d7a7c04ad5b8f49
BLAKE2b-256 379c888cc34c96b2b63d20669237472715f1458c34f3cd043edb4a14216b1932

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for yarl-1.2.3-cp35-cp35m-manylinux1_i686.whl
Algorithm Hash digest
SHA256 66706ce54c7297d173c2138a5a886646573299ddc1890f770500c682b7a6803b
MD5 8c90396fafbb300ee646741c222260e1
BLAKE2b-256 1a7f687b5768cdcdac4d0fd2ea31395fa3dad637428098029b0d08ae7b474ff9

See more details on using hashes here.

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