我们以猎聘网为例
进入后搜索想要爬取的岗位信息,右键选择 “检查” 进入开发者界面
点击右上角的network,选择doc
然后点击图中的搜索按钮,输入想要爬取的岗位名称,然后刷新页面,选择搜索下边的第二个
这个时候我们看到有我们需要的url,从中也可知网站的请求方式为get请求,我们也得用get请求!
部分代码解析:
import parsel
import requests
import csv
url = 'https://www.liepin.com/zhaopin/'
这个是网页中payload的参数,也就是url中问号后面的参数
data = {
'inputFrom': 'www_index',
'workYearCode': '0',
'key': 'python',
'scene': 'input',
'ckId': 'kfpt1emhvkrshc9o4h2xquxd74pfihmb',
}
请求头在网页中Request headers的最后面
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) '
'Chrome/99.0.4844.74 Safari/537.36 Edg/99.0.1150.46 '
}
网页中用的是get请求,我们也得用get请求
response = requests.get(url=url, headers=headers, params=data)
选择网页中的css
selector = parsel.Selector(response.text)
lis = selector.css('.left-list-box .job-list-item')
for li in lis:
title = li.css('.job-title-box div:nth-child(1)::attr(title)').get() # 标题
city = li.css('.job-dq-box .ellipsis-1::text').get() # 城市
money = li.css('.job-detail-header-box .job-salary::text').get() # 薪资
tag_list = li.css('.job-labels-box .labels-tag::text').getall() # 标签
exp = tag_list[0] # 经验要求
edu = tag_list[1] # 学历要求
tag = ','.join(tag_list[2:])
company_name = li.css('.company-name::text').get() # 公司名称
company_list = li.css('.company-tags-box span::text').getall() # 公司标签
company_tag = ','.join(company_list)
href = li.css('.job-detail-box a:nth-child(1)::attr(href)').get() # 详情页
','.join()用逗号把列表里面的元素合并成一个字符串数据
定义一个dit字典存放所需要的信息
dit = {
'标题': title,
'城市': city,
'薪资': money,
'经验要求': exp,
'学历要求': edu,
'职位标签': tag,
'公司名称': company_name,
'公司标签': company_tag,
'详情页': href,
}
f = open('招聘.csv', mode='a', encoding='utf-8', newline='')
css_write = csv.DictWriter(f, fieldnames=[
'标题',
'城市',
'薪资',
'经验要求',
'学历要求',
'职位标签',
'公司名称',
'公司标签',
'详情页',
])
css_write.writerow(dit) # 写入表头
# 打印在python中显示
print(title, city, money, exp, edu, tag, company_name, company_tag, href)
import parsel
import requests
import csv
f = open('招聘.csv', mode='a', encoding='utf-8', newline='')
css_write = csv.DictWriter(f, fieldnames=[
'标题',
'城市',
'薪资',
'经验要求',
'学历要求',
'职位标签',
'公司名称',
'公司标签',
'详情页',
])
url = 'https://www.liepin.com/zhaopin/'
data = {
'inputFrom': 'www_index',
'workYearCode': '0',
'key': 'python',
'scene': 'input',
'ckId': 'kfpt1emhvkrshc9o4h2xquxd74pfihmb',
}
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) '
'Chrome/99.0.4844.74 Safari/537.36 Edg/99.0.1150.46 '
}
response = requests.get(url=url, headers=headers, params=data)
selector = parsel.Selector(response.text)
# 把最大的标签提取出来
lis = selector.css('.left-list-box .job-list-item')
for li in lis:
title = li.css('.job-title-box div:nth-child(1)::attr(title)').get() # 标题
city = li.css('.job-dq-box .ellipsis-1::text').get() # 城市
money = li.css('.job-detail-header-box .job-salary::text').get() # 薪资
tag_list = li.css('.job-labels-box .labels-tag::text').getall() # 标签
exp = tag_list[0] # 经验要求
edu = tag_list[1] # 学历要求
# ','.join()用逗号把列表里面的元素合并成一个字符串数据
tag = ','.join(tag_list[2:])
company_name = li.css('.company-name::text').get() # 公司名称
company_list = li.css('.company-tags-box span::text').getall() # 公司标签
company_tag = ','.join(company_list)
href = li.css('.job-detail-box a:nth-child(1)::attr(href)').get() # 详情页
dit = {
'标题': title,
'城市': city,
'薪资': money,
'经验要求': exp,
'学历要求': edu,
'职位标签': tag,
'公司名称': company_name,
'公司标签': company_tag,
'详情页': href,
}
css_write.writerow(dit) # 写入表头
# 打印
print(title, city, money, exp, edu, tag, company_name, company_tag, href)