get post 请求 函数封装

本文介绍了一个简单的Python网络爬虫实现方法,通过使用urllib库完成GET和POST请求,能够从指定URL抓取网页内容,并处理了常见的网络请求异常。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

# 导包
from urllib import request,parse
# 导入urllib.error包中 HTTPError,URLError 模块   异常捕获
from urllib.error import HTTPError,URLError

# 再次封装 如果是get请求直接调用 get(url,headers=None) ###headers可不写
# a.get(url,headers=None)
def get(url,headers=None):
    return urlrequests(url,headers=headers)
# 再次封装 如果是post请求直接调用 post(url,form,headers=None) ### headers可不写
def post(url,form,headers=None):
    return urlrequests(url,form,headers=headers)

#1. 传入url
#2. user_agent
#3. headers
#4. 定义Request
#5. urlopen
#6. 返回byte数组
def urlrequests(url,form=None,headers=None):
    # 判断headers是否存在,如果不存在使用自定义headers
    if headers==None:
        headers = {
            'User-Agent': ' Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 Safari/537.36'
        }
    html_bytes = b''#倒成二进制bytes格式
    try:
        # 如果form存在,为post请求执行if内程序
        if form:
            # POST
            # 2.1转换成str
            form_str=parse.urlencode(form)
            # 2.2转换成bytes
            from_bytes=form_str.encode('utf-8')
            req=request.Request(url,data=from_bytes,headers=headers)
        # 如果form不存在,为get请求执行else内程序
        else:
            # get
            req=request.Request(url,headers=headers)
        response = request.urlopen(req)#第二个参数设置为timeout 如果请求超时会报出except URLError错误
        html_bytes=response.read()
    except HTTPError as a:
        print(a)
    except URLError as e:
        print (e)
    except Exception as s:
        print(s)
    return html_bytes


if __name__ == '__main__':
    # url = 'http://fanyi.baidu.com/sug'
    # form = {
    #     'kw': '呵呵'
    # }
    # html_bytes = post(url, form=form)
    # print(html_bytes)

    url='http://www.baidu.com'#写入想要爬取的网站地址
    html_bytes =get(url)
    print(html_bytes)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值