Request

Request对象在我们写爬虫发送请求的时候调用,参数如下:

  • url: 就是需要请求的url

  • callback: 指定该请求返回的Response由那个函数来处理。

  • method: 请求方法,默认GET方法,可设置为"GET", "POST", "PUT"等,且保证字符串大写

  • headers: 请求时,包含的头文件。一般不需要。内容一般如下:

    • Host: media.readthedocs.org

    • User-Agent: Mozilla/5.0 (Windows NT 6.2; WOW64; rv:33.0) Gecko/20100101 Firefox/33.0

    • Accept: text/css,/;q=0.1

    • Accept-Language: zh-cn,zh;q=0.8,en-us;q=0.5,en;q=0.3

    • Accept-Encoding: gzip, deflate

    • Referer: http://scrapy-chs.readthedocs.org/zh_CN/0.24/

    • Cookie: _ga=GA1.2.1612165614.1415584110;

    • Connection: keep-alive

    • If-Modified-Since: Mon, 25 Aug 2014 21:59:35

    • GMT Cache-Control: max-age=0

  • meta: 在不同的解析函数之间传递数据使用的。字典dict型

    # -*- coding: utf-8 -*-
    import scrapy
    from TencentHR.items import TencenthrItem

    class HrSpider(scrapy.Spider):
       name = 'hr'
       # allowed_domains = ['ddd']
       start_urls = ['https://hr.tencent.com/position.php']

       def parse(self, response):
           trs = response.xpath('//table[@class="tablelist"]/tr[@class="odd"] | //table[@class="tablelist"]/tr[@class="even"]')
           # print(len(trs))
           for tr in trs:
               items = TencenthrItem()
               detail_url = tr.xpath('./td/a/@href').extract()[0]
               items['position_name'] = tr.xpath('./td/a/text()').extract()[0]
               try:
                   items['position_type'] = tr.xpath('./td[2]/text()').extract()[0]
               except:
                   print("{}职位没有类型,url为{}".format(items['position_name'], "https://hr.tencent.com/" + detail_url))
                   items['position_type'] = None
               items['position_num'] = tr.xpath('./td[3]/text()').extract()[0]
               items['publish_time'] = tr.xpath('./td[5]/text()').extract()[0]
               items['work_addr'] = tr.xpath('./td[4]/text()').extract()[0]

               detail_url = 'https://hr.tencent.com/' + detail_url
               yield scrapy.Request(detail_url,
                                    comallback=self.parse_detail,
                                    meta={"items":items}
                                    )
               
           next_url = response.xpath('//a[text()="下一页"]/@href').extract_first()
           next_url = 'https://hr.tencent.com/' + next_url
           print(next_url)
           yield scrapy.Request(next_url,
                                callback=self.parse
                              )

       def parse_detail(self,response):
           items = response.meta['items']
           items["work_duty"] = response.xpath('//table[@class="tablelist textl"]/tr[3]//li/text()').extract()
           items["work_require"] =response.xpath('//table[@class="tablelist textl"]/tr[4]//li/text()').extract()
           yield items
  • encoding: 使用默认的 'utf-8' 就行。

  • dont_filter: 表明该请求不由调度器过滤。这是当你想使用多次执行相同的请求,忽略重复的过滤器。默认为False。

  • errback: 指定错误处理函数

Response

Response属性和可以调用的方法

  • meta: 从其他解析函数传递过来的meta属性,可以保持多个解析函数之间的数据连接

  • encoding: 返回当前字符串编码和编码的格式

  • text: 返回Unicode字符串

  • body: 返回bytes字符串

  • xpath: 可以调用xpath方法解析数据

  • css: 调用css选择器解析数据

发送POST请求

  • 当我们需要发送Post请求的时候,就调用Request中的子类FormRequest 来实现,如果需要在爬虫一开始的时候就发送post请求,那么需要在爬虫类中重写 start_requests(self) 方法, 并且不再调用start_urls中的url

  • 案例 登录豆瓣网

    # -*- coding: utf-8 -*-
    import scrapy

    class TestSpider(scrapy.Spider):
       name = 'login'
       allowed_domains = ['www.douban.com']
       # start_urls = ['http://www.baidu.com/']

       def start_requests(self):
           login_url = "https://accounts.douban.com/j/mobile/login/basic"
           headers = {
               'Referer': 'https://accounts.douban.com/passport/login_popup?login_source=anony',
               'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.103 Safari/537.36'
          }
           formdata = {
               'ck': '',
               'name': 用户名,
               'password': 密码,
               'remember': 'true',
               'ticket': ''
          }
           request = scrapy.FormRequest(login_url, callback=self.parse, formdata=formdata, headers=headers)
           yield request

       def parse(self, response):
           print(response.text)
  • 返回结果,可以看到登录成功了

    {"status":"success","message":"success","description":"处理成功","payload":{"account_info":{"name":"仅此而已","weixin_binded":false,"phone":"手机号","avatar":{"medium":"https://img3.doubanio.com\/icon\/user_large.jpg","median":"https://img1.doubanio.com\/icon\/user_normal.jpg","large":"https://img3.doubanio.com\/icon\/user_large.jpg","raw":"https://img3.doubanio.com\/icon\/user_large.jpg","small":"https://img1.doubanio.com\/icon\/user_normal.jpg","icon":"https://img3.doubanio.com\/pics\/icon\/user_icon.jpg"},"id":"193317985","uid":"193317985"}}}
  • 登录成功之后请求个人主页,可以看到我们可以访问登录之后的页面了

# -*- coding: utf-8 -*-
import scrapy class TestSpider(scrapy.Spider):
name = 'login'
allowed_domains = ['www.douban.com']
# start_urls = ['http://www.baidu.com/'] def start_requests(self):
login_url = "https://accounts.douban.com/j/mobile/login/basic"
headers = {
'Referer': 'https://accounts.douban.com/passport/login_popup?login_source=anony',
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.103 Safari/537.36'
}
formdata = {
'ck': '',
'name': 用户名,
'password': 密码,
'remember': 'true',
'ticket': ''
}
request = scrapy.FormRequest(login_url, callback=self.parse, formdata=formdata, headers=headers)
yield request def parse(self, response):
print(response.text)
# 登录成功之后访问个人主页
url = "https://www.douban.com/people/193317985/"
yield scrapy.Request(url=url, callback=self.parse_detail) def parse_detail(self, response):
print(response.text)

  

Request、Response的更多相关文章

  1. Request 、Response 与Server的使用

    纯属记录总结,以下图片都是来自 ASP.NET笔记之 Request .Response 与Server的使用 Request Response Server 关于Server.MapPath 方法看 ...

  2. LoadRunner中取Request、Response

    LoadRunner中取Request.Response LoadRunner两个“内置变量”: 1.REQUEST,用于提取完整的请求头信息. 2.RESPONSE,用于提取完整的响应头信息. 响应 ...

  3. struts2中获取request、response,与android客户端进行交互(文件传递给客户端)

    用struts2作为服务器框架,与android客户端进行交互需要得到request.response对象. struts2中获取request.response有两种方法. 第一种:利用Servle ...

  4. 第十五节:HttpContext五大核心对象的使用(Request、Response、Application、Server、Session)

    一. 基本认识 1. 简介:HttpContext用于保持单个用户.单个请求的数据,并且数据只在该请求期间保持: 也可以用于保持需要在不同的HttpModules和HttpHandlers之间传递的值 ...

  5. java web(四):request、response一些用法和文件的上传和下载

    上一篇讲了ServletContent.ServletCOnfig.HTTPSession.request.response几个对象的生命周期.作用范围和一些用法.今天通过一个小项目运用这些知识.简单 ...

  6. @ModelAttribute设置request、response、session对象

    利用spring web提供的@ModelAttribute注解 放在类方法的参数前面表示引用Model中的数据 @ModelAttribute放在类方法上面则表示该Action类中的每个请求调用之前 ...

  7. spring aop 获取request、response对象

    在网上看到有不少人说如下方式获取: 1.在web.xml中添加监听 <listener>          <listener-class>              org. ...

  8. SpringMvc4中获取request、response对象的方法

    springMVC4中获取request和response对象有以下两种简单易用的方法: 1.在control层获取 在control层中获取HttpServletRequest和HttpServle ...

  9. springboot的junit4模拟request、response对象

    关键字: MockHttpRequest.Mock测试 问题: 在模拟junit的request.response对象时,会报如下空指针异常. 处理方法: 可用MockHttpServletReque ...

  10. 在SpringMVC中操作Session、Request、Response对象

    示例 @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper user ...

随机推荐

  1. Saiku根据入参日期查询出对应的数据(二十)

    Saiku根据入参日期查询出对应的数据 之前好像有写过一篇博客关于saiku date range的,现在进一步更新啦!!! 这里的日期筛选会更完善一些,需要提供两个参数 开始日期与结束日期(star ...

  2. Go 基础 坑

    1.字符串空为"" 2. 传递的数组是原数组的拷贝,所以是无法通过传递数组的方法去修改原地址的数据的.在GO语言中除了切片(slice).集合(map).通道(channel)和接 ...

  3. react-redux-reducer

    reducer是对dispatch(action)的响应,是一个纯函数,接受旧的state和action,返回新的state. //纯函数要注意的点,下面的例子myname不变 <script& ...

  4. 6 python高级数据处理和可视化

    6.2. pyplot作图 1.折线图和散点图 t = np.arange(0,4,0.1) plt.plot(t,t,'o',t,t+2,t,t**2,'o') plt.show() 2.柱线图 p ...

  5. 背景图片利用backgrond-posintion属性实现不同形式的分割

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  6. C++二维数组、指针、对象数组、对象指针

    项目中用到,随手记一下: 1.二维数组.与指针 创建二维数组指针的方式: a.已知一维的大小 1 int **array=new int *[rows]; 2 (for int i=0;i<ro ...

  7. java 秒时间格式化

    public static String durationFormat(Integer totalSeconds) { if (totalSeconds == null || totalSeconds ...

  8. RN android真机调试找不到设备

    待完成…… 1.adb驱动安装 2.手机设置 3.添加adb_usb.ini文件

  9. python中的lambda表达式

    lambda是python中匿名函数的写法  我们可以在不定义函数名的情况下一边定义并调用这个函数 例子: 普通方法定义函数:def  plus(a,b): return a+b lambda方法  ...

  10. NIO 概述 与 通信实例

    NIO 简述: NIO是在jdk1.4之后加入的一种基于缓冲区(buffer)和通道(channel)的I/O方式, nio是同步非阻塞的i/o模式,同步是指线程不断地轮询i/o事件,非阻塞是在处理i ...