urllib通过Post请求爬去数据并解析JSON(Python)

1.   封装的请求post函数:

def downloadPostPage(url, dictdata, headers, charset='utf-8', reqnum=5):
    data = bytes(parse.urlencode(dictdata), encoding=charset)
    req = request.Request(url, data, headers=headers,method='POST')
    info= None
    try:
        response = request.urlopen(req)
        info = response.read().decode(charset)
    except error.HTTPError as e:
        # 服务器错误
        print(e.code)
        if reqnum > 0:
            if hasattr(e, 'code') and 500 <= e.code <= 600:
                time.sleep(random.randint(5, 11))
                downloadPostPage(url,dictdata,headers, charset=charset, reqnum=reqnum-1)
    except error.URLError:
        print("url error")
    return info

2.   主函数的实现:

if __name__ == '__main__':
    url = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&smartresult=ugc&sessionFrom=null'
    headers = {
        "Accept": "application/json, text/javascript, */*; q=0.01",
        "X-Requested-With": "XMLHttpRequest",
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64; rv:45.0) Gecko/20100101 Firefox/45.0",
        "Content-Type": "application/x-www-form-urlencoded; charset=UTF-8",
    }
    while True:
        key = input('输入搜索词:')
        if not key:
            break
        dictdata = {
            "i": key,
            "from": "auto",
            "to": "auto",
            "smartresult": "dict",
            "client": "fanyideskweb",
            "salt": "1511219405946",
            "sign": "f8965f67a1d3eee8a69ddf8ccc5f582b",
            "doctype": "json",
            "version": "2.1",
            "keyfrom": "fanyi.web",
            "action": "FY_BY_REALTIME",
            "typoResult": "false"
        }
        info = downloadPostPage(url, dictdata, headers=headers,reqnum=1)
        jsonLoads = json.loads(info)
        print(jsonLoads)
        print(jsonLoads['translateResult'][0][0]['tgt'])


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LIJZ_Python

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值