python数据分析工程师招聘_Python爬取智联招聘数据分析师岗位相关信息的方法

进入智联招聘官网,在搜索界面输入‘数据分析师',界面跳转,按F12查看网页源码,点击network

2019081311082351.png

选中XHR,然后刷新网页

2019081311082352.png

可以看到一些Ajax请求, 找到画红线的XHR文件,点击可以看到网页的一些信息

2019081311082353.png

2019081311084454.png

2019081311084455.png

在Header中有Request URL,我们需要通过找寻Request URL的特点来构造这个请求网址,

点击Preview,可以看到我们所需要的信息就存在result中,这信息基本是json格式,有些是列表;

下面我们通过Python爬虫来爬取上面的信息;

代码如下:

import requests

from urllib.parse import urlencode

import json

#from requests import codes

#import os

#from hashlib import md5

#from multiprocessing.pool import Pool

#import re

def get_page(offset):

params = {

'start': offset,

'pageSize': '90',

'cityId': '530',

'salary': '0,0',

'workExperience': '-1',

'education': '-1',

'companyType': '-1',

'employmentType': '-1',

'jobWelfareTag': '-1',

'kw': '数据分析师',

'kt': '3',

'_v': '0.77091902',

'x-zp-page-request-id': '8ff0aa73bf834b408f46324e44d89b84-1562722989022-210101',

'x-zp-client-id': '2dc4c9a4-e80d-4488-84a3-03426dd69a1e'

}

base_url = 'https://fe-api.zhaopin.com/c/i/sou?'

url = base_url + urlencode(params)

try:

resp = requests.get(url)

print(url)

if 200 == resp.status_code:

print(resp.json())

return resp.json()

except requests.ConnectionError:

return None

def get_information(json_page):

if json_page.get('data'):

results = json_page.get('data').get('results')

for result in results:

yield {

'city': result.get('city').get('display'),

'company': result.get('company').get('name'),

#'welfare':result.get('welfare'),

'workingExp':result.get('workingExp').get('name'),

'salary':result.get('salary'),

'eduLevel':result.get('eduLevel').get('name')

}

print('succ')

def write_to_file(content):

with open('result.txt','a',encoding='utf-8') as f:

print(type(json.dumps(content)))

f.write(json.dumps(content,ensure_ascii=False)+'\n')

def main(offset):

json_page=get_page(offset)

for content in get_information(json_page):

write_to_file(content)

if __name__=='__main__':

for i in range(10):

main(offset=90*i)

爬取结果如下:

2019081311084456.png

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

本文标题: Python爬取智联招聘数据分析师岗位相关信息的方法

本文地址: http://www.cppcns.com/jiaoben/python/268258.html

好的,以下是一个示例代码,用于爬取智联招聘网站上的数据分析师工作岗位信息: ```python import requests from bs4 import BeautifulSoup url = 'https://fe-api.zhaopin.com/c/i/sou?start=0&pageSize=60&cityId=489&industry=10100&salary=0,0&workExperience=-1&education=-1&companyType=-1&employmentType=-1&jobWelfareTag=-1&kw=数据分析师&kt=3&_v=0.97530866&x-zp-page-request-id=8d3f7b1e6c9a4c8e9dc8a2a6bb605d4e-1626243117597-609241' headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36 Edge/16.16299' } response = requests.get(url, headers=headers) soup = BeautifulSoup(response.content, 'html.parser') job_list = soup.find_all('div', {'class': 'job-list'}) for job in job_list: job_name = job.find('a', {'target': '_blank', 'data-jid': True}).text.strip() job_salary = job.find('span', {'class': 'salary'}).text.strip() job_company = job.find('a', {'class': 'company-name'}).text.strip() job_location = job.find('span', {'class': 'job-area'}).text.strip() job_experience = job.find('span', {'class': 'job-exp'}).text.strip() print(job_name, job_salary, job_company, job_location, job_experience) ``` 在这个示例代码中,我们设置了筛选条件,只爬取数据分析师工作岗位信息。同时,我们使用了 requests 库向智联招聘网站发送了一个 HTTP 请求,并设置了请求头部信息,以避免被网站识别为爬虫。然后,我们使用 BeautifulSoup 库解析了页面内容,并从中提取出了工作岗位信息。 您可以根据自己的需求修改代码中的参数和条件,以获得您需要的工作岗位信息。注意,爬取网站信息时要遵守相关法律法规和网站规定,不要过度频繁地请求网站,以免对网站造成影响。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值