urllib.request和urllib.parse模块

常用的方法

urllib.requests.ulopen(“网址”):向网站发起一个请求并获取响应

from urllib import request

resp = request.urlopen("http://www.baidu.com")
print(resp.geturl())# 具体请求的网址
print(resp.getcode())
print(resp.read(10))# 读取10字节
print(resp.readline())#读取第一行
print(resp.readlines())# 读取每一行,列表返回
  1. 下载图片或其他资源:
from urllib import request
lady_url=""
request.urlretrieve(lady_url,"lady.jpg")

urllib.parse

  1. urlencode 将字典进行url编码
from urllib import parse

url="https://www.baidu.com/s"
params={"wd":"刘德华"}
qs=parse.urlencode(params)
url=url+"?"+qs
print(url)
  1. parse_qs urlencode的逆
from urllib import parse
params={"wd":"刘德华"}
qs=parse.urlencode(params)
print(parse.parse_qs(qs))

3.urlparse urlsplit,解析url

url="https://www.baidu.com/s/w?wd=python&username=abd#2"
result=parse.urlparse(url)
print(result)
print(result.fragment)
print(result.path)
result=parse.urlsplit(url)
print(result)
打印结果:
ParseResult(scheme='https', netloc='www.baidu.com', path='/s/w', params='', query='wd=python&username=abd', fragment='2')
2
/s/w
SplitResult(scheme='https', netloc='www.baidu.com', path='/s/w', query='wd=python&username=abd', fragment='2')

区别是:只有一个,urlparse会多解析一个params

你可能感兴趣的:(urllib.request和urllib.parse模块)