python-scrapy爬取某招聘网站信息(一)

首先准备python3+scrapy+mysql+pycharm。。。html

此次咱们选择爬取智联招聘网站的企业招聘信息,首先咱们有针对的查看网站的html源码,发现其使用的是js异步加载的方式,直接从服务端调取json数据,这就意味着咱们用地址栏的网址获取的网站内容是不全的,没法得到想要的数据。java

那么咱们用什么方式获取想要的数据呢,正所谓道高一尺魔高一丈,有反爬虫就有范反爬虫,固然咱们不用那么麻烦,经过分析页面的加载有针对性的抓包获取信息进行分析,咱们会发现每次刷新或者搜索页面时候,除了会加载许多图片、广告等信息外,还加载了一个包,这个包里就有咱们想要的全部信息,而且服务端都给咱们打包成json格式了,这样看似复杂,实则简化了咱们对数据进行过滤的步骤。python

 

 

直接从头文件中找到请求的url源头,那么就能直接获取json数据了。 怎么样是否是感觉到了世界的友好呢?mysql

分析完毕,接下来就能够编写爬虫数据了。。。sql

1、建立爬虫项目数据库

在命令行中在指定的目录建立爬虫项目json

scrapy startproject zhilian

而后就是建立爬虫文件api

scrapy genspider zhaopin "sou.zhaopin.com"  
#要把http://www去掉由于爬虫项目运行时会自动加上,这里也是为了不没必要要的错误

2、编写程序app

首先编写item文件,咱们有选择的爬取几个关键数据dom

import scrapy class ZhilianItem(scrapy.Item): # 岗位名称 jobName = scrapy.Field() # 公司名称 companyName = scrapy.Field() # 工做地点 workSite = scrapy.Field() # 更新日期 updateDate = scrapy.Field() # 薪资水平 salaryLevel = scrapy.Field() # 岗位关键词 jobKeyWord = scrapy.Field()

而后就是编写爬虫文件了咱们的命名为zhaopin.py

# -*- coding: utf-8 -*- import json import scrapy from zhilian.items import ZhilianItem class zhaopinSpider(scrapy.Spider): name = 'javaDevelop' allowed_domains = ['sou.zhaopin.com'] offset = 0 url1 = "https://fe-api.zhaopin.com/c/i/sou?start=" url2 = "&pageSize=90&cityId=530&workExperience=-1&education=-1&companyType=-1&employmentType=-1&jobWelfareTag=-1&kw=%E7%BB%8F%E6%B5%8E&kt=3" start_urls = ( url1 + str(offset) + url2,  #此为咱们简化后的网址,网址的规律至关简单,简单试试就找到规律了 ) print(start_urls) def parse(self, response):for flag in range(0, 90): item = ZhilianItem() job = json.loads(response.text)['data']['results'][flag] # 岗位名称 item['jobName'] = job['jobName'] # 公司名称 item['companyName'] = job['company']['name'] # 工做地点 item['workSite'] = job['city']['display'] # 更新日期 item['updateDate'] = job['updateDate'] # 薪资水平 item['salaryLevel'] = job['salary'] # 岗位关键词 item['jobKeyWord'] = job['welfare'] yield item if self.offset < 450: self.offset += 90
            yield scrapy.Request(self.url1 + str(self.offset) + self.url2, callback=self.parse, dont_filter=True)
       #dont_filter=True这个参数至关重要,指不过滤url直接爬取。不然你会发现你的爬虫爬取完第一页后就不会再爬取了,这样是由于url与爬取域url不符,爬虫自动认为爬取结束

接下来就是写管道文件了,这里我用了两种方式,一种是写到数据库中,还有一种是写道本地txt文件中

import pymysql class zhaoPipeline(object): def __init__(self): self.conn = pymysql.connect(host='172.18.96.151', user='root', password='123456', db='zhilian', charset='utf8' ) self.cur = self.conn.cursor() def process_item(self, item, spider): # 岗位名称
        jobName = item['jobName'] # 公司名称
        companyName = item['companyName'] # 工做地点
        workSite = item['workSite'] # 官网连接
        updateDate = item['updateDate'] # 薪资水平
        salaryLevel = item['salaryLevel'] # 岗位关键词
        jobKeyWord = item['jobKeyWord'] data = [jobName, companyName, workSite, updateDate, salaryLevel, ','.join(jobKeyWord)] print(data) print("======================================") sql = """ insert into zhaopin (jobname,companyname,worksite,updatedate,salarylevel,jobkeyword) values (%s,%s,%s,%s,%s,%s) """
        # self.conn.ping(reconnect=True)
 self.cur.execute(sql, data) self.conn.commit() def close_spider(self, spider): self.cur.close() self.conn.close() class ZhilianPipeline(object): def __init__(self): self.filename = open("java.txt", 'wb') # self.path = "G:\images\p"
        # if not os.path.exists(self.path):
        # os.mkdir(self.path)

    def process_item(self, item, spider): # 岗位名称
        jobName = item['jobName'] # 公司名称
        companyName = item['companyName'] # 工做地点
        workSite = item['workSite'] # 官网连接
        updateDate = item['updateDate'] # 薪资水平
        salaryLevel = item['salaryLevel'] # 岗位关键词
        jobKeyWord = item['jobKeyWord'] self.filename.write(jobName.encode('utf-8') + '    '.encode('utf-8') + companyName.encode('utf-8') + '   '.encode('utf-8') + workSite.encode('utf-8') + '    '.encode('utf-8') + updateDate.encode('utf-8') + '    '.encode('utf-8') + salaryLevel.encode('utf-8') + '    '.encode('utf-8') + ','.join(jobKeyWord).encode('utf-8') + '\n'.encode('utf-8')) return item def close_spider(self, spider): self.filename.close()

手把手教学,咱们附上创建库语句

create table zhaopin (id int(10) not null primary key AUTO_INCREMENT, jobname varchar(40), companyname varchar(20), worksite varchar(10), updatedate datetime, salarylevel varchar(10), jobkeyword varchar(40) );

而后就剩下最后的设置setting了,下面三个关键的地方要改

ROBOTSTXT_OBEY = False

DEFAULT_REQUEST_HEADERS = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.87 Safari/537.36', # 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8', # 'Accept-Language': 'en', }

ITEM_PIPELINES = {
'zhilian.pipelines.ZhilianPipeline': 300,
'zhilian.pipelines.zhaoPipeline': 200,
}

3、运行爬虫

scrapy crawl zhaopin

等待片刻,刷新数据表

 

 OVER。。。

相关文章
相关标签/搜索