Получить протокол + имя хоста из URL - PullRequest
130 голосов
/ 09 марта 2012

В моем приложении Django мне нужно получить имя хоста от реферера в request.META.get('HTTP_REFERER') вместе с его протоколом, чтобы из URL-адресов, таких как:

Я должен получить:

Я просмотрел другие связанные вопросы и нашел относительно urlparse, но это не помогло, так как

>>> urlparse(request.META.get('HTTP_REFERER')).hostname
'docs.google.com'

Ответы [ 12 ]

239 голосов
/ 09 марта 2012

Вы должны быть в состоянии сделать это с urlparse (документы: python2 , python3 ):

from urllib.parse import urlparse
# from urlparse import urlparse  # Python 2
parsed_uri = urlparse('http://stackoverflow.com/questions/1234567/blah-blah-blah-blah' )
result = '{uri.scheme}://{uri.netloc}/'.format(uri=parsed_uri)
print(result)

# gives
'http://stackoverflow.com/'
72 голосов
/ 09 марта 2012

https://github.com/john-kurkowski/tldextract

Это более подробная версия urlparse.Он обнаруживает домены и субдомены для вас.

Из их документации:

>>> import tldextract
>>> tldextract.extract('http://forums.news.cnn.com/')
ExtractResult(subdomain='forums.news', domain='cnn', suffix='com')
>>> tldextract.extract('http://forums.bbc.co.uk/') # United Kingdom
ExtractResult(subdomain='forums', domain='bbc', suffix='co.uk')
>>> tldextract.extract('http://www.worldbank.org.kg/') # Kyrgyzstan
ExtractResult(subdomain='www', domain='worldbank', suffix='org.kg')

ExtractResult - это именованный кортеж, поэтому доступ к нужным вам элементам прост.

37 голосов
/ 22 декабря 2013

Python3 с использованием urlsplit :

from urllib.parse import urlsplit
url = "/5252100/poluchit-protokol-imya-hosta-iz-url"
base_url = "{0.scheme}://{0.netloc}/".format(urlsplit(url))
print(base_url)
# http://stackoverflow.com/
22 голосов
/ 14 апреля 2016

Операции с чистой строкой:):

>>> url = "/5252100/poluchit-protokol-imya-hosta-iz-url"
>>> url.split("//")[-1].split("/")[0].split('?')[0]
'stackoverflow.com'
>>> url = "stackoverflow.com/questions/9626535/get-domain-name-from-url"
>>> url.split("//")[-1].split("/")[0].split('?')[0]
'stackoverflow.com'
>>> url = "http://foo.bar?haha/whatever"
>>> url.split("//")[-1].split("/")[0].split('?')[0]
'foo.bar'

Вот и все, ребята.

19 голосов
/ 26 августа 2015
>>> import urlparse
>>> url = 'http://stackoverflow.com/questions/1234567/blah-blah-blah-blah'
>>> urlparse.urljoin(url, '/')
'http://stackoverflow.com/'
7 голосов
/ 07 мая 2018

если вы считаете, что ваш URL действителен, то это будет работать постоянно

domain = "http://google.com".split("://")[1].split("/")[0] 
5 голосов
/ 23 ноября 2017

Вот немного улучшенная версия:

urls = [
    "http://stackoverflow.com:8080/some/folder?test=/questions/9626535/get-domain-name-from-url",
    "Stackoverflow.com:8080/some/folder?test=/questions/9626535/get-domain-name-from-url",
    "http://stackoverflow.com/some/folder?test=/questions/9626535/get-domain-name-from-url",
    "https://StackOverflow.com:8080?test=/questions/9626535/get-domain-name-from-url",
    "stackoverflow.com?test=questions&v=get-domain-name-from-url"]
for url in urls:
    spltAr = url.split("://");
    i = (0,1)[len(spltAr)>1];
    dm = spltAr[i].split("?")[0].split('/')[0].split(':')[0].lower();
    print dm

выход

stackoverflow.com
stackoverflow.com
stackoverflow.com
stackoverflow.com
stackoverflow.com

Скрипка: https://pyfiddle.io/fiddle/23e4976e-88d2-4757-993e-532aa41b7bf0/?i=true

4 голосов
/ 08 июня 2013

Что-то не так с чистыми строковыми операциями:

url = '/5252100/poluchit-protokol-imya-hosta-iz-url'
parts = url.split('//', 1)
print parts[0]+'//'+parts[1].split('/', 1)[0]
>>> http://stackoverflow.com

Если вы предпочитаете добавить косую черту, расширьте этот скрипт примерно так:

parts = url.split('//', 1)
base = parts[0]+'//'+parts[1].split('/', 1)[0]
print base + (len(url) > len(base) and url[len(base)]=='/'and'/' or '')

Возможно, этобыть немного оптимизирован ...

2 голосов
/ 09 марта 2012

Это немного глупо, но использует urlparse в обоих направлениях:

import urlparse
def uri2schemehostname(uri):
    urlparse.urlunparse(urlparse.urlparse(uri)[:2] + ("",) * 4)

этот нечетный ("",) * 4 бит, потому что urlparse ожидает последовательность точно len(urlparse.ParseResult._fields)= 6

0 голосов
/ 25 февраля 2019

для получения домена / имени хоста и источника *

url = '/5252100/poluchit-protokol-imya-hosta-iz-url'
hostname = url.split('/')[2] # stackoverflow.com
origin = '/'.join(url.split('/')[:3]) # https://stackoverflow.com

*Origin используется в XMLHttpRequest заголовках

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...