Skip to content

yarl.URL

__slots__ class-attribute instance-attribute

__slots__ = (
    "_cache",
    "_scheme",
    "_netloc",
    "_path",
    "_query",
    "_fragment",
)

_fragment instance-attribute

_fragment: str

_netloc instance-attribute

_netloc: str

_path instance-attribute

_path: str

_query instance-attribute

_query: str

_scheme instance-attribute

_scheme: str

__bool__

__bool__() -> bool

__bytes__

__bytes__() -> bytes

__eq__

__eq__(other: object) -> bool

__ge__

__ge__(other: object) -> bool

__getstate__

__getstate__() -> tuple[SplitResult]

__gt__

__gt__(other: object) -> bool

__hash__

__hash__() -> int

__init_subclass__

__init_subclass__()

__le__

__le__(other: object) -> bool

__lt__

__lt__(other: object) -> bool

__mod__

__mod__(query: Query) -> URL

__new__

__new__(
    val: Union[
        str, SplitResult, URL, UndefinedType
    ] = UNDEFINED,
    *,
    encoded: bool = False,
    strict: Union[bool, None] = None
) -> URL

__repr__

__repr__() -> str

__setstate__

__setstate__(state)

__str__

__str__() -> str

__truediv__

__truediv__(name: str) -> URL

_cache_netloc

_cache_netloc() -> None

Cache the netloc parts of the URL.

_make_child

_make_child(
    paths: Sequence[str], encoded: bool = False
) -> URL

add paths to self._path, accounting for absolute vs relative paths, keep existing, but do not create new, empty segments

_origin

_origin() -> URL

Return an URL with scheme, host and port parts only.

user, password, path, query and fragment are removed.

_parsed_query

_parsed_query() -> list[tuple[str, str]]

Parse query part of URL.

_val

_val() -> SplitURLType

absolute

absolute() -> bool

A check for absolute URLs.

Return True for absolute ones (having scheme or starting with //), False otherwise.

authority

authority() -> str

Decoded authority part of URL.

Empty string for relative URLs.

build classmethod

build(
    *,
    scheme: str = "",
    authority: str = "",
    user: Union[str, None] = None,
    password: Union[str, None] = None,
    host: str = "",
    port: Union[int, None] = None,
    path: str = "",
    query: Union[Query, None] = None,
    query_string: str = "",
    fragment: str = "",
    encoded: bool = False
) -> URL

Creates and returns a new URL

explicit_port

explicit_port() -> Union[int, None]

Port part of URL, without scheme-based fallback.

None for relative URLs or URLs without explicit port.

extend_query

extend_query(query: Query) -> URL
extend_query(**kwargs: QueryVariable) -> URL
extend_query(*args: Any, **kwargs: Any) -> URL

Return a new URL with query part combined with the existing.

This method will not remove existing query parameters.

Example:

url = URL('http://example.com/?a=1&b=2') url.extend_query(a=3, c=4) URL('http://example.com/?a=1&b=2&a=3&c=4')

fragment

fragment() -> str

Decoded fragment part of URL.

Empty string if fragment is missing.

host

host() -> Union[str, None]

Decoded host part of URL.

None for relative URLs.

host_port_subcomponent

host_port_subcomponent() -> Union[str, None]

Return the host and port subcomponent part of URL.

Trailing dots are removed from the host part.

This value is suitable for use in the Host header of an HTTP request.

None for relative URLs.

https://datatracker.ietf.org/doc/html/rfc3986#section-3.2.2 IP-literal = "[" ( IPv6address / IPvFuture ) "]" https://datatracker.ietf.org/doc/html/rfc3986#section-3.2.3 port = *DIGIT

Examples: - http://example.com:8080 -> example.com:8080 - http://example.com:80 -> example.com - http://example.com.:80 -> example.com - https://127.0.0.1:8443 -> 127.0.0.1:8443 - https://[::1]:8443 -> [::1]:8443 - http://[::1] -> [::1]

host_subcomponent

host_subcomponent() -> Union[str, None]

Return the host subcomponent part of URL.

None for relative URLs.

https://datatracker.ietf.org/doc/html/rfc3986#section-3.2.2

IP-literal = "[" ( IPv6address / IPvFuture ) "]"

Examples: - http://example.com:8080 -> example.com - http://example.com:80 -> example.com - https://127.0.0.1:8443 -> 127.0.0.1 - https://[::1]:8443 -> [::1] - http://[::1] -> [::1]

human_repr

human_repr() -> str

Return decoded human readable string for URL representation.

is_absolute

is_absolute() -> bool

A check for absolute URLs.

Return True for absolute ones (having scheme or starting with //), False otherwise.

Is is preferred to call the .absolute property instead as it is cached.

is_default_port

is_default_port() -> bool

A check for default port.

Return True if port is default for specified scheme, e.g. 'http://python.org' or 'http://python.org:80', False otherwise.

Return False for relative URLs.

join

join(url: URL) -> URL

Join URLs

Construct a full (“absolute”) URL by combining a “base URL” (self) with another URL (url).

Informally, this uses components of the base URL, in particular the addressing scheme, the network location and (part of) the path, to provide missing components in the relative URL.

joinpath

joinpath(*other: str, encoded: bool = False) -> URL

Return a new URL with the elements in other appended to the path.

name

name() -> str

The last part of parts.

origin

origin() -> URL

Return an URL with scheme, host and port parts only.

user, password, path, query and fragment are removed.

parent

parent() -> URL

A new URL with last part of path removed and cleaned up query and fragment.

parts

parts() -> tuple[str, ...]

A tuple containing decoded path parts.

('/',) for absolute URLs if path is missing.

password

password() -> Union[str, None]

Decoded password part of URL.

None if password is missing.

path

path() -> str

Decoded path of URL.

/ for absolute URLs without path part.

path_qs

path_qs() -> str

Decoded path of URL with query.

path_safe

path_safe() -> str

Decoded path of URL.

/ for absolute URLs without path part.

/ (%2F) and % (%25) are not decoded

port

port() -> Union[int, None]

Port part of URL, with scheme-based fallback.

None for relative URLs or URLs without explicit port and scheme without default port substitution.

query

query() -> MultiDictProxy[str]

A MultiDictProxy representing parsed query parameters in decoded representation.

Empty value if URL has no query part.

query_string

query_string() -> str

Decoded query part of URL.

Empty string if query is missing.

raw_authority

raw_authority() -> str

Encoded authority part of URL.

Empty string for relative URLs.

raw_fragment

raw_fragment() -> str

Encoded fragment part of URL.

Empty string if fragment is missing.

raw_host

raw_host() -> Union[str, None]

Encoded host part of URL.

None for relative URLs.

When working with IPv6 addresses, use the host_subcomponent property instead as it will return the host subcomponent with brackets.

raw_name

raw_name() -> str

The last part of raw_parts.

raw_parts

raw_parts() -> tuple[str, ...]

A tuple containing encoded path parts.

('/',) for absolute URLs if path is missing.

raw_password

raw_password() -> Union[str, None]

Encoded password part of URL.

None if password is missing.

raw_path

raw_path() -> str

Encoded path of URL.

/ for absolute URLs without path part.

raw_path_qs

raw_path_qs() -> str

Encoded path of URL with query.

raw_query_string

raw_query_string() -> str

Encoded query part of URL.

Empty string if query is missing.

raw_suffix

raw_suffix() -> str

raw_suffixes

raw_suffixes() -> tuple[str, ...]

raw_user

raw_user() -> Union[str, None]

Encoded user part of URL.

None if user is missing.

relative

relative() -> URL

Return a relative part of the URL.

scheme, user, password, host and port are removed.

scheme

scheme() -> str

Scheme for absolute URLs.

Empty string for relative URLs or URLs starting with //

suffix

suffix() -> str

suffixes

suffixes() -> tuple[str, ...]

update_query

update_query(query: Query) -> URL
update_query(**kwargs: QueryVariable) -> URL
update_query(*args: Any, **kwargs: Any) -> URL

Return a new URL with query part updated.

This method will overwrite existing query parameters.

Example:

url = URL('http://example.com/?a=1&b=2') url.update_query(a=3, c=4) URL('http://example.com/?a=3&b=2&c=4')

user

user() -> Union[str, None]

Decoded user part of URL.

None if user is missing.

with_fragment

with_fragment(fragment: Union[str, None]) -> URL

Return a new URL with fragment replaced.

Autoencode fragment if needed.

Clear fragment to default if None is passed.

with_host

with_host(host: str) -> URL

Return a new URL with host replaced.

Autoencode host if needed.

Changing host for relative URLs is not allowed, use .join() instead.

with_name

with_name(
    name: str,
    *,
    keep_query: bool = False,
    keep_fragment: bool = False
) -> URL

Return a new URL with name (last part of path) replaced.

Query and fragment parts are cleaned up.

Name is encoded if needed.

with_password

with_password(password: Union[str, None]) -> URL

Return a new URL with password replaced.

Autoencode password if needed.

Clear password if argument is None.

with_path

with_path(
    path: str,
    *,
    encoded: bool = False,
    keep_query: bool = False,
    keep_fragment: bool = False
) -> URL

Return a new URL with path replaced.

with_port

with_port(port: Union[int, None]) -> URL

Return a new URL with port replaced.

Clear port to default if None is passed.

with_query

with_query(query: Query) -> URL
with_query(**kwargs: QueryVariable) -> URL
with_query(*args: Any, **kwargs: Any) -> URL

Return a new URL with query part replaced.

Accepts any Mapping (e.g. dict, multidict.MultiDict instances) or str, autoencode the argument if needed.

A sequence of (key, value) pairs is supported as well.

It also can take an arbitrary number of keyword arguments.

Clear query if None is passed.

with_scheme

with_scheme(scheme: str) -> URL

Return a new URL with scheme replaced.

with_suffix

with_suffix(
    suffix: str,
    *,
    keep_query: bool = False,
    keep_fragment: bool = False
) -> URL

Return a new URL with suffix (file extension of name) replaced.

Query and fragment parts are cleaned up.

suffix is encoded if needed.

with_user

with_user(user: Union[str, None]) -> URL

Return a new URL with user replaced.

Autoencode user if needed.

Clear user/password if user is None.

without_query_params

without_query_params(*query_params: str) -> URL

Remove some keys from query part and return new URL.