Получить протокол + имя хоста из URL
В моем приложении Django мне нужно получить имя хоста от реферера в request.META.get('HTTP_REFERER')
вместе с его протоколом, чтобы из URL-адресов, таких как:
Я должен получить:
Я просмотрел другие связанные вопросы и нашел относительно urlparse, но это не помогло
>>> urlparse(request.META.get('HTTP_REFERER')).hostname
'docs.google.com'
Ответы
Ответ 1
Вы должны быть в состоянии сделать это с помощью 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/'
Ответ 2
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
- это именованный элемент, поэтому вам просто нужно получить доступ к частям, которые вы хотите.
>>> ext = tldextract.extract('http://forums.bbc.co.uk')
>>> ext.domain
'bbc'
>>> '.'.join(ext[:2]) # rejoin subdomain and domain
'forums.bbc'
Ответ 3
Python3 с помощью urlsplit:
from urllib.parse import urlsplit
url = "http://stackoverflow.com/questions/9626535/get-domain-name-from-url"
base_url = "{0.scheme}://{0.netloc}/".format(urlsplit(url))
print(base_url)
# http://stackoverflow.com/
Ответ 4
Чисто строковые операции :):
>>> url = "http://stackoverflow.com/questions/9626535/get-domain-name-from-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'
Это все, ребята.
Ответ 5
>>> import urlparse
>>> url = 'http://stackoverflow.com/questions/1234567/blah-blah-blah-blah'
>>> urlparse.urljoin(url, '/')
'http://stackoverflow.com/'
Ответ 6
Вот немного улучшенная версия:
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
Ответ 7
если вы думаете, что ваш URL действителен, то это будет работать все время
domain = "http://google.com".split("://")[1].split("/")[0]
Ответ 8
Что-то не так с чистыми строковыми операциями:
url = 'http://stackoverflow.com/questions/9626535/get-domain-name-from-url'
parts = url.split('//', 1)
print parts[0]+'//'+parts[1].split('/', 1)[0]
>>> http://stackoverflow.com
Если вы предпочитаете иметь прикрепляемую косую черту, добавьте этот script немного так:
parts = url.split('//', 1)
base = parts[0]+'//'+parts[1].split('/', 1)[0]
print base + (len(url) > len(base) and url[len(base)]=='/'and'/' or '')
Возможно, это немного оптимизировано...
Ответ 9
Это немного тупо, но использует urlparse
в обоих направлениях:
import urlparse
def uri2schemehostname(uri):
urlparse.urlunparse(urlparse.urlparse(uri)[:2] + ("",) * 4)
этот нечетный бит ("",) * 4
заключается в том, что urlparse ожидает последовательность точно len(urlparse.ParseResult._fields)
= 6
Ответ 10
Если он содержит менее 3 косых черт, значит, он у вас есть, а если нет, то мы можем найти вхождение между ними:
import re
link = http://forum.unisoftdev.com/something
slash_count = len(re.findall("/", link))
print slash_count # output: 3
if slash_count > 2:
regex = r'\:\/\/(.*?)\/'
pattern = re.compile(regex)
path = re.findall(pattern, url)
print path
Ответ 11
Я знаю, это старый вопрос, но я тоже столкнулся с ним сегодня. Решил это с помощью одной строки:
import re
result = re.sub(r'(.*://)?([^/?]+).*', '\g<1>\g<2>', url)
Ответ 12
получить домен/имя хоста и происхождение *
url = 'https://stackoverflow.com/questions/9626535/get-protocol-host-name-from-url'
hostname = url.split('/')[2] # stackoverflow.com
origin = '/'.join(url.split('/')[:3]) # https://stackoverflow.com
* Origin
используется в заголовках XMLHttpRequest
Ответ 13
Вы можете использовать urlparse
из библиотеки urllib
:
from urllib.parse import urlparse
o = urlparse("http://www.example.com/br/pages/")
domain = "://".join([o.scheme, o.netloc])