从URL获取protocol+主机名

2024-04-19 16:45:11 发布

您现在位置:Python中文网/ 问答频道 /正文

在我的Django应用程序中,我需要从request.META.get('HTTP_REFERER')中的referer获取主机名及其协议,以便从如下URL获取:

我应该得到:

我查看了其他相关的问题,发现了关于urlparse的问题,但这并没有起到作用,因为

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

Tags: httpscomhttpdocsgetexamplerequestwww
3条回答

你应该可以用urlparse(文档:python2python3)来完成它:

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/'

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是一个namedtuple,因此访问所需的部分很简单。

>>> ext = tldextract.extract('http://forums.bbc.co.uk')
>>> ext.domain
'bbc'
>>> '.'.join(ext[:2]) # rejoin subdomain and domain
'forums.bbc'

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/

相关问题 更多 >