(一)Request库简要分析及通用框架

Requests库


1、安装
                cmd下    pip install requests

 

2、Requests七种方法

  • request.request()构造请求,支撑下面的方法
  • request.get()    获取HTML网页的主要方法
  • request.head()     获取HTML网页头信息方法,对应http的head(数据流大情况下使用,自获取头部信息)
  • request.post()    向HTML网页提交post请求,对应http的post
  • request.put()  向HTML网页提交PUT请求,对应http的put
  • request.patch() 向HTML网页提交局部修改请求,对http的patch
  • request.delete()向HTML页面提交删除请求,对应http的delete

3Response属性

  • r.text返回请求信息
  • r.status_code返回状态,200:正常,其他失败
  • r.encoding 从html头部信息猜编码方式
  • r.apparent_encoding根据内容分析
  • r.content_二进制显示内容

4、爬去信息主要常用


r = requests.get(url,params = None,**kwargs)

  1. url :你获取页面的url链接
  2. params:url中的额外参数,字典或字节流格式,可选
  3. **kwargs:常见控制访问参数:
  •  params:字典或字节序列,作为参数增加到url中
  • data:字典或字节序列或文件对象,作为Request内容
  • json:JSON格式的数据,作为Request内容
  • headers:子弹,HTTP定制头
  • cookie:字典或cookiejar,Request中的cookie
  • auth:元组,支持http认证功能
  • timeout :设置超时时间单位秒
  • proxies:设置代理服务器

爬去网页通用代码框架

# coding=<encoding name>
#coding= UTF-8
import requests
from idlelib.iomenu import encoding
def getHtmlText(url):
    try:
        r = requests.get(url, timeout = 30)
        r.raise_for_status()#如果状态不是200,引发HTTPError异常
        r.encoding = r.apparent_encoding#r.encoding = r.apparent_encoding()
        #print(r.headers)
        return r.text
    except:
        return "产生异常"
if __name__ == "__main__":
    url = "http://www.baidu.com"
    print(getHtmlText(url))

 

Java的世界里,HttpClient 是一个功能强大的Http请求,然而接口非常复杂,设计上遵从正交性,简单的请求也需要写比较多的代码,更不要说隐藏在各种细节里面的高级用法了。Requests,  是一个模仿python requests 模块来设计的Http lib,拥有简单而灵活的API,在容易使用的同时,又能够满足各种高级定制的使用,可是说是当前最好用的Java Http Client Lib。 简单的请求示例:String url = ...; Response resp = Requests.get(url).text(); // post 和其他方法 resp = Requests.post(url).text(); resp = Requests.head(url).text(); //读取Http Response  int statusCode = resp.getStatusCode(); Headers headers = resp.getHeaders(); Cookies cookies = resp.getCookies(); String body = resp.getBody(); //response 返回其他类型 resp = Requests.get(url).text("UTF-8"); // get response as bytes Response resp1 = Requests.get(url).bytes(); // save response as file  Response resp2 = Requests.get(url).file("/path/to/save/file"); // url 参数: Map map = new HashMap(); map.put("k1", "v1"); map.put("k2", "v2"); Response resp = Requests.get(url).param("key1", "value1").params(map)         //.params(new Parameter(...), new Parameter(...))         .text(); // 请求头 Response resp = Requests.get(url).header("key1", "value1").headers(map)         //.headers(new Header(...), new Header(...))         .text(); // 添加Cookie: Map cookies = new HashMap(); Response resp = Requests.get(url).cookie("key1", "value1").cookies(map)         //.cookies(new Cookie(...), new Cookie(...))         .text(); //  设置 userAgent Response resp = Requests.get(url).userAgent(userAgent).text(); // 增加请求数据(post, put, patch方法) // send form-encoded data. x-www-form-urlencoded header will be send automatically Response resp = Requests.post(url).data(map).text(); // send string data String str = ...; resp = Requests.post(url).data(str, "UTF-8").text(); // send from inputStream InputStream in = ... resp = Requests.post(url).data(in).text(); // multipart 请求, 用于文件上传: Response resp = Requests.post(url).data(map).multiPart("ufile", "/path/to/file")         .multiPart(..., ...).text();请求设置://禁止自动重定向
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值