Skip to main content

Extract the top level domain (TLD) from the URL given.

Project description

Extract the top level domain (TLD) from the URL given. List of TLD names is taken from Mozilla.

Optionally raises exceptions on non-existing TLDs or silently fails (if fail_silently argument is set to True).

Prerequisites

  • Python 2.6, 2.7, 3.4, 3.5, 3.6 and PyPy

Documentation

Documentation is available on Read the Docs.

Installation

Latest stable version on PyPI:

pip install tld

Or latest stable version from GitHub:

pip install https://github.com/barseghyanartur/tld/archive/stable.tar.gz

Or latest stable version from BitBucket:

pip install https://bitbucket.org/barseghyanartur/tld/get/stable.tar.gz

Usage examples

Get the TLD name as string from the URL given:

from tld import get_tld, get_fld

get_tld("http://www.google.co.uk")
# 'co.uk'

get_fld("http://www.google.co.uk")
# 'google.co.uk'

get_tld("http://www.google.idontexist", fail_silently=True)
# None

get_fld("http://www.google.idontexist", fail_silently=True)
# None

If you wish, you could get the TLD as an object:

from tld import get_tld

res = get_tld("http://some.subdomain.google.co.uk", as_object=True)

res
# 'co.uk'

res.subdomain
# 'some.subdomain'

res.domain
# 'google'

res.tld
# 'co.uk'

res.fld
# 'google.co.uk'

Get TLD name, ignoring the missing protocol:

from tld import get_tld, get_fld

get_tld("www.google.co.uk", fix_protocol=True)
# 'co.uk'

get_fld("www.google.co.uk", fix_protocol=True)
# 'google.co.uk'

Update the list of TLD names

To update/sync the tld names with the most recent version run the following from your terminal:

update-tld-names

Or simply do:

from tld.utils import update_tld_names

update_tld_names()

Troubleshooting

If somehow domain names listed here are not recognised, make sure you have the most recent version of TLD names in your virtual environment:

update-tld-names

Testing

Simply type:

./runtests.py

Or use tox:

tox

Or use tox to check specific env:

tox -e py36

Writing documentation

Keep the following hierarchy.

=====
title
=====

header
======

sub-header
----------

sub-sub-header
~~~~~~~~~~~~~~

sub-sub-sub-header
^^^^^^^^^^^^^^^^^^

sub-sub-sub-sub-header
++++++++++++++++++++++

sub-sub-sub-sub-sub-header
**************************

License

MPL 1.1/GPL 2.0/LGPL 2.1

Support

For any issues contact me at the e-mail given in the Author section.

Author

Artur Barseghyan <artur.barseghyan@gmail.com>

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

tld-0.9.tar.gz (246.9 kB view details)

Uploaded Source

Built Distribution

tld-0.9-py2.py3-none-any.whl (224.6 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file tld-0.9.tar.gz.

File metadata

  • Download URL: tld-0.9.tar.gz
  • Upload date:
  • Size: 246.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for tld-0.9.tar.gz
Algorithm Hash digest
SHA256 a81904f2d5d8d70c4542e5e7be4b297037b9abc0a34832d6653432b4c0aad960
MD5 93d67629d4510d21903808fd2e8e57a0
BLAKE2b-256 8002a3503571810816e348c8b508022cdcae6b7f5044b4ab9e7e4cd428820ef3

See more details on using hashes here.

File details

Details for the file tld-0.9-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for tld-0.9-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 1fb0a29566e6a126be8298d14224a51fef8cd8904c010b0d5a0a8e4a17dbe302
MD5 57efbfc43e328210cc2550b97381a916
BLAKE2b-256 fa78dbeaeb20db795c42deb81271fd65a35c040ce2e946024eaeef5c6b184176

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