本文整理匯總了Python中future.moves.urllib.parse.urlparse方法的典型用法代碼示例。如果您正苦於以下問題:Python parse.urlparse方法的具體用法?Python parse.urlparse怎麽用?Python parse.urlparse使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類future.moves.urllib.parse
的用法示例。
在下文中一共展示了parse.urlparse方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: save_file
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def save_file(self, local_file_path=None, remote_file_path=None, file_obj=None):
"""
保存本地文件至weed_fs文件係統
{"name":"test.csv","size":425429}
"""
assign = self._get_assign()
url = 'http://%s/%s' % (assign['url'], assign['fid'])
if local_file_path:
file_obj = open(local_file_path, 'rb')
elif remote_file_path:
headers = {'Host': urlparse(remote_file_path).netloc} # 防反爬, 指定圖片 Host
headers.update(self.request_headers)
res = requests.get(remote_file_path, headers=headers, timeout=REQUESTS_TIME_OUT)
if res.status_code == 200:
file_obj = res.content
else:
raise Exception('File does not exist')
elif not file_obj:
raise Exception('File does not exist')
res = requests.post(url, files={'file': file_obj}, timeout=REQUESTS_TIME_OUT)
return dict(res.json(), **assign)
示例2: token_stage
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def token_stage():
# find out where this account is
xframe, user_discovery_uri, resource = do_autodiscover(config['domain'])
# Get the inbound token as posted from a form
token = request.form['access_token']
state = request.form['session_state']
# discover which web server we have been assigned to
user_discovery_data = do_user_discovery(resource, token, config)
# Link to the current session server resource (we need a token for this.)
instance_url = user_discovery_data['_links']['applications']['href']
instance_parts = urlparse(instance_url)
instance_resource = '{0}://{1}'.format(instance_parts.scheme, instance_parts.netloc)
url = grant_flow_token(config['client_id'],
config['redirect_uri'] + '/directsession',
instance_resource, state, token)
return redirect(url)
示例3: api_request
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def api_request(url, method="get", params=None, ret_key=None):
params = params or {}
resp = None
try:
method = method.lower()
params = build_api_key(urlparse(url).path, params)
if method == "get":
resp = getattr(requests, method)(url, params=params)
else:
resp = getattr(requests, method)(url, data=params)
if resp.status_code != 200:
return abort(resp.status_code, resp.json().get("message"))
resp = resp.json()
if ret_key is not None:
return resp.get(ret_key)
return resp
except Exception as e:
code = e.code if hasattr(e, "code") else None
if isinstance(code, int) and resp is not None:
return abort(code, resp.json().get("message"))
current_app.logger.warning(url)
current_app.logger.warning(params)
current_app.logger.error(str(e))
return abort(500, "server unknown error")
示例4: decode_url_connection_string
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def decode_url_connection_string(conn_str):
"""URL connection string into more useful parts"""
parse_result = urlparse(conn_str)
try:
decoded = dict()
decoded['scheme'] = parse_result.scheme
decoded['username'] = parse_result.username
decoded['password'] = parse_result.password
decoded['hostname'] = parse_result.hostname
decoded['port'] = parse_result.port
decoded['database'] = __split_db_and_table_path(parse_result.path)[0]
# decoded['table'] = __split_db_and_table_path(parse_result.path)[1]
if any(v in {None, ''} for k, v in decoded.items()):
return None
except IndexError:
return None
return decoded
示例5: decode_simple_url_conn_string
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def decode_simple_url_conn_string(conn_str):
"""URL connection string into more useful parts"""
parse_result = urlparse(conn_str)
try:
decoded = dict()
decoded['scheme'] = parse_result.scheme
decoded['hostname'] = parse_result.hostname
decoded['port'] = parse_result.port
decoded['path'] = parse_result.path
if any(v in {None, ''} and (k in ('scheme', 'hostname', 'path'))
for k, v in decoded.items()):
return None
except IndexError:
return None
return decoded
示例6: _make_qr
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def _make_qr(builder, oauth, meta, config_dict, lets_connect, secret=None):
# type: (Gtk.builder, str, Metadata, dict, bool, Any) -> None
image = builder.get_object('totp-qr-image')
if not secret:
secret = gen_base32()
host = urlparse(meta.api_base_uri).netloc
uri = "otpauth://totp/{user_id}@{host}?secret={secret}&issuer={host}".format(user_id=meta.user_id, host=host,
secret=secret)
qr = qrcode.QRCode(box_size=7, border=2)
qr.add_data(uri)
qr.make()
img = qr.make_image()
pixbuf = pil2pixbuf(img)
image.set_from_pixbuf(pixbuf)
GLib.idle_add(lambda: _parse_user_input(builder, oauth, meta, config_dict=config_dict,
lets_connect=lets_connect, secret=secret))
# ui thread
示例7: authorize
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def authorize(auth_url, user, password):
browser = mechanicalsoup.StatefulBrowser(raise_on_404=True)
logger.info("opening auth_url")
response = browser.open(auth_url)
assert(response.ok)
browser.select_form('form[action="/vpn-user-portal/_form/auth/verify"]')
browser["userName"] = user
browser["userPass"] = password
logger.info("logging in")
response = browser.submit_selected()
assert(response.ok)
form = browser.select_form()
if 'action' in form.form.attrs and form.form.attrs['action'] == '/vpn-user-portal/_two_factor/auth/verify/totp':
raise EduvpnAuthException("otp enabled")
assert(urlparse(browser.get_url()).path == "/vpn-user-portal/_oauth/authorize") # make sure is the right page
form = browser.select_form()
form.form.select('button[value="yes"]')
logger.info("authorising app")
response = browser.submit_selected()
assert(response.ok)
示例8: str_to_url
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def str_to_url(value):
"""
Returns a UUID(value) if the value provided is a str.
:param value: str or UUID object
:return: UUID object
"""
return urlparse(value) if isinstance(value, string_types) else value
示例9: to_json_dict
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def to_json_dict(self, skip_id=False):
if self.url is not None:
try:
url_parsed = urlparse(self.url)
netloc = url_parsed.netloc
except Exception as e:
logger.error(e)
netloc = None
else:
netloc = None
d = {
'unique_name': self.unique_name,
'name': self.name,
'url': self.url,
'is_builtin': self.is_builtin,
'netloc': netloc,
'version': self.version,
'enable_acl': self.enable_acl,
'enable_hmac': self.enable_hmac,
'require_login': self.require_login,
'async_http_connect_timeout': self.async_http_connect_timeout,
'async_http_request_timeout': self.async_http_request_timeout,
'memo': self.memo,
}
if hasattr(self, 'enable'):
d['enable'] = self.enable
# 是否要過濾id
if not skip_id:
d['id'] = self.id
if hasattr(self, 'acl_rules'):
d['acl_rules'] = [t.to_json_dict(skip_id) for t in self.acl_rules]
return d
示例10: prepare_url
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def prepare_url(self):
url_parsed = urlparse(self.raw_base_url)
items = url_parsed.path.split('/')
if len(items) > 0:
item = items[-1]
items = items[:-1]
new_path = '/'.join(items)
else:
item = ''
new_path = url_parsed.path
url = urlunparse((url_parsed.scheme, url_parsed.netloc, new_path, '', '', ''))
if item.endswith('.php'):
self.site_lang = 'php'
elif item.endswith('.asp'):
self.site_lang = 'asp'
elif item.endswith('.aspx'):
self.site_lang = 'aspx'
if self.site_lang != '':
logger.info('site_lang: %s' % self.site_lang)
self.base_url = url
self.first_item = item
logger.info('base_url: %s' % url)
logger.info('first_item: %s' % item)
示例11: get_update_url
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def get_update_url(url, data):
"""
獲取更新後的url
:param url:
:param data:
:return:
"""
result = urlparse(url)
query_payload = dict(parse_qsl(result.query), **data)
query_param = urlencode(query_payload)
return urlunparse((result.scheme, result.netloc, result.path, result.params, query_param, result.fragment))
示例12: get_url_query_param
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def get_url_query_param(url, param):
"""
獲取url參數值
:param url:
:param param:
:return:
"""
result = urlparse(url)
return dict(parse_qsl(result.query)).get(param)
示例13: allow_url
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def allow_url(url, allow_domains):
url_parse = urlparse(url)
result = False
for domain in allow_domains:
if url_parse.netloc.endswith(domain):
result = True
return result
示例14: do_autodiscover
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def do_autodiscover(domain):
r = requests.get('https://webdir.online.lync.com/autodiscover/autodiscoverservice.svc/root?originalDomain=%s' % domain)
discovery = r.json()
path = discovery['_links']['user']['href']
domain = urlparse(path)
host = '{0}://{1}'.format(domain.scheme, domain.netloc)
return (discovery['_links']['xframe']['href'], path, host)
示例15: get_file
# 需要導入模塊: from future.moves.urllib import parse [as 別名]
# 或者: from future.moves.urllib.parse import urlparse [as 別名]
def get_file(self, url='', path=''):
'''It is possible to mimic FTP bulk data downloads using the \
HTTP-based data distribution server at https://oceandata.sci.gsfc.nasa.gov.
:param url: a single file name which can be obtained by calling #file_search() \
an example would be \
https://oceandata.sci.gsfc.nasa.gov/cgi/getfile/O1997001.L3b_DAY_CHL.nc
:type url: :mod:`string`
:param path: Destination directory into which the granule \
needs to be downloaded.
:type path: :mod:`string`
:returns: a file object downloaded from the \
HTTP-based data distribution server at https://oceandata.sci.gsfc.nasa.gov.
'''
try:
# url = GET_URL
if url:
url = url
else:
raise Exception("'file' parameter is required!")
file = os.path.basename(urlparse(url).path)
if path == '':
path = os.path.join(os.path.dirname(__file__), file)
else:
path = path + '/' + file
urlretrieve(url, path)
print("Downloaded '%s' to '%s'" % (file, path))
return file
except Exception as e:
print(e)
raise