各位大佬,我想爬取51job的求职详细信息,具体要求是进入官网搜索数字化管理,进到搜索结果页

获取里面的职位名称,薪资等信息,再点击进入每个职位的详细页面,获取里面的岗位职责等具体要求,

我写了一个代码,可以爬取第一个搜索页的 职位名称和薪资等信息,但进到详细页的时候 无法获取详细页的岗位职责等具体信息。

报错信息如下:

import requests
import json
import pandas as pd
from bs4 import BeautifulSoup# 创建空列表,用于存储数据
post_list = []# 使用一个列表来收集所有的文字内容
texts = []for page in range(1, 51):# 设置请求urlpost_url = f'https://we.51job.com/api/job/search-pc?api_key=51job&timestamp=1696320374&keyword=%E6%95%B0%E5%AD%97%E5%8C%96%E7%AE%A1%E7%90%86&searchType=2&function=&industry=&jobArea=000000&jobArea2=&landmark=&metro=&salary=&workYear=&degree=&companyType=&companySize=&jobType=&issueDate=&sortType=0&pageNum={page}&requestId=&pageSize=20&source=1&accountId=&pageCode=sou%7Csou%7Csoulb&u_atoken=2ca6e1ae-fa70-41cd-9e38-a08a9e95fb76&u_asession=012t7pRyhGHOghJrYjhVbiG_PenymPB204JRWRSfcWGwvAwkrxQ73PCUt4w2x1lHHznKe-6CQQK6f87md9nMUZctsq8AL43dpOnCClYrgFm6o&u_asig=05k1bKQDkEecjNCG4spv3X0zAV1aEpt0GCCadwzkQrqKTfF1rOoApB5y4ZzMCcE-eWFH6J5a6axjxBy5YYl2LbmqejDiWCeGgyk2CvT8POaE6b0Q6BWSrXgqfhVZ4zHNT20-DqeciYycsNAPQsoqAeMww9q1Sbz5kFQVmRJDgEk_2Rjoy8b6Iyz3ADPMhizAKlksmHjM0JOodanL5-M1Qs1esPktKn_g6n51y0G4V_gzb5l1Tkmp4k4Q-65Vosvt9CJ-JJElOzXY6Opa0trnxsxeg4cbkiKv5-ovPTXDpGPGfY94r_LXIIil3Y3aVPRGAe&u_aref=9x2J%2FTRy3QJabllhhmNJLuq7vyM%3D'# 设置请求头headers = {'Accept': 'application/json, text/plain, */*','Accept-Encoding': 'gzip, deflate, br','Accept-Language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6,zh-TW;q=0.5','Connection': 'keep-alive','Cookie': "nsearch=jobarea%3D%26%7C%26ord_field%3D%26%7C%26recentSearch0%3D%26%7C%26recentSearch1%3D%26%7C%26recentSearch2%3D%26%7C%26recentSearch3%3D%26%7C%26recentSearch4%3D%26%7C%26collapse_expansion%3D; search=jobarea%7E%60%7C%21recentSearch0%7E%60000000%A1%FB%A1%FA000000%A1%FB%A1%FA0000%A1%FB%A1%FA00%A1%FB%A1%FA99%A1%FB%A1%FA%A1%FB%A1%FA99%A1%FB%A1%FA99%A1%FB%A1%FA99%A1%FB%A1%FA99%A1%FB%A1%FA9%A1%FB%A1%FA99%A1%FB%A1%FA%A1%FB%A1%FA0%A1%FB%A1%FA%CA%FD%D7%D6%BB%AF%B9%DC%C0%ED%A1%FB%A1%FA2%A1%FB%A1%FA1%7C%21recentSearch1%7E%60030800%A1%FB%A1%FA030831%A1%FB%A1%FA0000%A1%FB%A1%FA00%A1%FB%A1%FA99%A1%FB%A1%FA%A1%FB%A1%FA99%A1%FB%A1%FA99%A1%FB%A1%FA99%A1%FB%A1%FA99%A1%FB%A1%FA9%A1%FB%A1%FA99%A1%FB%A1%FA%A1%FB%A1%FA0%A1%FB%A1%FA%CA%FD%BE%DD%B7%D6%CE%F6%A1%FB%A1%FA2%A1%FB%A1%FA1%7C%21; guid=905277a987104111f0c174845049ec13; slife=lowbrowser%3Dnot%26%7C%26; privacy=1696725594; acw_tc=ac11000116967255980824819e00e15bc47e8c5565cf103e1376789d6cd3b6; sensorsdata2015jssdkcross=%7B%22distinct_id%22%3A%22905277a987104111f0c174845049ec13%22%2C%22first_id%22%3A%2218aef5ba1abb18-0093b34e2b677418-78505775-1338645-18aef5ba1ac28c%22%2C%22props%22%3A%7B%22%24latest_traffic_source_type%22%3A%22%E8%87%AA%E7%84%B6%E6%90%9C%E7%B4%A2%E6%B5%81%E9%87%8F%22%2C%22%24latest_search_keyword%22%3A%22%E6%9C%AA%E5%8F%96%E5%88%B0%E5%80%BC%22%2C%22%24latest_referrer%22%3A%22https%3A%2F%2Fcn.bing.com%2F%22%7D%2C%22identities%22%3A%22eyIkaWRlbnRpdHlfY29va2llX2lkIjoiMThhZWY1YmExYWJiMTgtMDA5M2IzNGUyYjY3NzQxOC03ODUwNTc3NS0xMzM4NjQ1LTE4YWVmNWJhMWFjMjhjIiwiJGlkZW50aXR5X2xvZ2luX2lkIjoiOTA1Mjc3YTk4NzEwNDExMWYwYzE3NDg0NTA0OWVjMTMifQ%3D%3D%22%2C%22history_login_id%22%3A%7B%22name%22%3A%22%24identity_login_id%22%2C%22value%22%3A%22905277a987104111f0c174845049ec13%22%7D%2C%22%24device_id%22%3A%2218aef5ba1abb18-0093b34e2b677418-78505775-1338645-18aef5ba1ac28c%22%7D; acw_sc__v2=6521fa61c4101175d8ceecf8bac489ed20327812; JSESSIONID=057B6308069316097F90AD9FD9295C45; ssxmod_itna=Qq+hY5AICDO3GHD8Yi40IuPCTd1xGxDv6mfKdD/YbGDnqD=GFDK40oYOoriAKiNw9m3xAxFmCOifqjFro2f+EDrc4eDHxY=DUgD+YYD4RKGwD0eG+DD4DWDmeHDnxAQDjxGpc2LkX=DEDYpZDit6D7tD5eDjAk6RYeG0DDt7n4G2tC=DYbd4EMbgK7TqFqDMteGXbYaiFkbaOPeZ9CWq4QpRDB=1xBQMCQUdx0PyBMUDZr+W8i4YSEh0++G4egDoQS4vk0Gd8BGjZoeo90Y4Dg+LSE4iDD396iD=; ssxmod_itna2=Qq+hY5AICDO3GHD8Yi40IuPCTd1xGxDv6mfKG9i=9DBwAg47P40q8+=WG2DkxFqG7GeD",'Dnt': '1','From-Domain': '51job_web','Host': 'we.51job.com','Property': "%7B%22partner%22%3A%22%22%2C%22webId%22%3A2%2C%22fromdomain%22%3A%2251job_web%22%2C%22frompageUrl%22%3A%22https%3A%2F%2Fwe.51job.com%2F%22%2C%22pageUrl%22%3A%22https%3A%2F%2Fwe.51job.com%2Fpc%2Fsearch%3Fkeyword%3D%25E6%2595%25B0%25E5%25AD%2597%25E5%258C%2596%25E7%25AE%25A1%25E7%2590%2586%26searchType%3D2%26sortType%3D0%26metro%3D%22%2C%22identityType%22%3A%22%22%2C%22userType%22%3A%22%22%2C%22isLogin%22%3A%22%E5%90%A6%22%2C%22accountid%22%3A%22%22%2C%22keywordType%22%3A%22%22%7D",'Referer': "https://we.51job.com/pc/search?keyword=%E6%95%B0%E5%AD%97%E5%8C%96%E7%AE%A1%E7%90%86&searchType=2&sortType=0&metro=",'Sec-Ch-Ua': '"Microsoft Edge";v="117", "Not;A=Brand";v="8", "Chromium";v="117"','Sec-Ch-Ua-Mobile': '?0','Sec-Ch-Ua-Platform': '"Windows"','Sec-Fetch-Dest': 'empty','Sec-Fetch-Mode': 'cors','Sec-Fetch-Site': 'same-origin','Sec-Gpc': '1','Partner': '','Sign': '0b6e7a413562570a7b9ceae46ce837e6b9956b3584d4916760031ddec36d36cf','User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/117.0.0.0 Safari/537.36 Edg/117.0.2045.47','User-Token': "",'Uuid': 'd37f9ef2faf49c91ca3b8e9137b95e08'}# 发送请求post_res = requests.get(url=post_url, headers=headers)# 获取响应数据post_data = post_res.json()for item in post_data['resultbody']['job']['items']:# 将数据存储到新字典中post_dict = {'职位名称': item['jobName'],'薪资': item['provideSalaryString'],'公司名称': item['fullCompanyName'],'工作能力要求': item['jobTags'],'工作详细要求链接': item['jobHref'],}# 进入详情页抓取职位具体信息detail_url = 'https://jobs.51job.com/' + item['hrefAreaPinYin'] + '/' + item['jobId'] + '.html'head = {'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7','Accept-Encoding': 'gzip, deflate, br','Accept-Language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6,zh-TW;q=0.5','Cache-Control': 'max-age=0','Connection': 'keep-alive','Cookie': 'nsearch=jobarea%3D%26%7C%26ord_field%3D%26%7C%26recentSearch0%3D%26%7C%26recentSearch1%3D%26%7C%26recentSearch2%3D%26%7C%26recentSearch3%3D%26%7C%26recentSearch4%3D%26%7C%26collapse_expansion%3D; search=jobarea%7E%60%7C%21recentSearch0%7E%60000000%A1%FB%A1%FA000000%A1%FB%A1%FA0000%A1%FB%A1%FA00%A1%FB%A1%FA99%A1%FB%A1%FA%A1%FB%A1%FA99%A1%FB%A1%FA99%A1%FB%A1%FA99%A1%FB%A1%FA99%A1%FB%A1%FA9%A1%FB%A1%FA99%A1%FB%A1%FA%A1%FB%A1%FA0%A1%FB%A1%FA%CA%FD%D7%D6%BB%AF%B9%DC%C0%ED%A1%FB%A1%FA2%A1%FB%A1%FA1%7C%21recentSearch1%7E%60030800%A1%FB%A1%FA030831%A1%FB%A1%FA0000%A1%FB%A1%FA00%A1%FB%A1%FA99%A1%FB%A1%FA%A1%FB%A1%FA99%A1%FB%A1%FA99%A1%FB%A1%FA99%A1%FB%A1%FA99%A1%FB%A1%FA9%A1%FB%A1%FA99%A1%FB%A1%FA%A1%FB%A1%FA0%A1%FB%A1%FA%CA%FD%BE%DD%B7%D6%CE%F6%A1%FB%A1%FA2%A1%FB%A1%FA1%7C%21; guid=905277a987104111f0c174845049ec13; slife=lowbrowser%3Dnot%26%7C%26; privacy=1696725594; sensorsdata2015jssdkcross=%7B%22distinct_id%22%3A%22905277a987104111f0c174845049ec13%22%2C%22first_id%22%3A%2218aef5ba1abb18-0093b34e2b677418-78505775-1338645-18aef5ba1ac28c%22%2C%22props%22%3A%7B%22%24latest_traffic_source_type%22%3A%22%E8%87%AA%E7%84%B6%E6%90%9C%E7%B4%A2%E6%B5%81%E9%87%8F%22%2C%22%24latest_search_keyword%22%3A%22%E6%9C%AA%E5%8F%96%E5%88%B0%E5%80%BC%22%2C%22%24latest_referrer%22%3A%22https%3A%2F%2Fcn.bing.com%2F%22%7D%2C%22identities%22%3A%22eyIkaWRlbnRpdHlfY29va2llX2lkIjoiMThhZWY1YmExYWJiMTgtMDA5M2IzNGUyYjY3NzQxOC03ODUwNTc3NS0xMzM4NjQ1LTE4YWVmNWJhMWFjMjhjIiwiJGlkZW50aXR5X2xvZ2luX2lkIjoiOTA1Mjc3YTk4NzEwNDExMWYwYzE3NDg0NTA0OWVjMTMifQ%3D%3D%22%2C%22history_login_id%22%3A%7B%22name%22%3A%22%24identity_login_id%22%2C%22value%22%3A%22905277a987104111f0c174845049ec13%22%7D%2C%22%24device_id%22%3A%2218aef5ba1abb18-0093b34e2b677418-78505775-1338645-18aef5ba1ac28c%22%7D; acw_sc__v2=6521fa61c4101175d8ceecf8bac489ed20327812; acw_tc=ac11000116967256843172336e00dfce5b8080ea2ff7bd0666eebafa0f2811; ssxmod_itna=eqGxuDRD9GDtzqBPGIrCADgADyGDcAniGQQ1rY=D0y0HeGzDAxn40iDtPrN=KhiST3tLe8BRePKFp2aL3sF2oub4LYCo4GLDmKDyber4GG0xBYDQxAYDGDDPDogPD1D3qDkD7h6CMy1qGWDm4sDY5HDQHGe4DFc2IOP4i7DDvQCx07YRKDe2ahchgCK0gDq0KD9hYDsZ2fe0KpjS3xM2oEI3B3Ix0kl40OyZAC74GdXc5z4/ueLG0o7gier=GxqniKTCG4vW4KYm29VADxT02xPAiF7OxxDDax65hx4D; ssxmod_itna2=eqGxuDRD9GDtzqBPGIrCADgADyGDcAniGQQ1rnDnI8KxDsaKDLG0=aH/+rV=N0r2d4uDnRGsOKG7BXOOz1CK2oTQePobtr2hA9vA/i3jA+OnKDUYv8u8ep6HR=8woCM6P2E=fOnmwkIlKDoXKevV0+KqaCKCKeEeNfix2Rd8zMAZ/r=T0qdu7lY8idNS0hQs0jN5gltroc6AR7KsiBfRtkKRQTQDPW9rOLdPWDHCtRjgQ4h5g+g42pIwA1GAlfYeY8d+A9cj=363M9uyYydTUtC+ReE+A1iwfIQyEdXEojbZ45ZWgHsjOIlGQ9mKc6NAWmEgpQhQnAK5fXErwlG=nQxj0jG==sWrwjYQ3PP/wq+q0n6/1irgtvxUZO0Zae2Dw792MWeSmUrILMZrDST7StKIrE060ZqSEr1+e+75RPQXj6IDUGSuBxUe+=2AIoULqUa+URw9Uw8nr4m0Sar3Ff3eWfNItUw9jERAv+DeA4DQKQD08DiQ7iGxB4QbY4dD','Dnt': '1','Host': 'jobs.51job.com','Referer': 'https://jobs.51job.com/dongguan-fgz/150702673.html?s=sou_sou_soulb&t=0_0&req=7bd49afc5d2508dd3008e440ec8c7978','Sec-Ch-Ua': '"Microsoft Edge";v="117", "Not;A=Brand";v="8", "Chromium";v="117"','Sec-Ch-Ua-Mobile': '?0','Sec-Ch-Ua-Platform': '"Windows"','Sec-Fetch-Dest': 'document','Sec-Fetch-Mode': 'navigate','Sec-Fetch-Site': 'same-origin','Sec-Fetch-User': '?1','Sec-Gpc': '1','Upgrade-Insecure-Requests': '1','User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/117.0.0.0 Safari/537.36 Edg/117.0.2045.47'}params = {'s': 'sou_sou_soulb','t': '0_0','req': '7bd49afc5d2508dd3008e440ec8c7978','timestamp__1258': 'n4+xuDRDgAYx0DU2DBMroDkWgY4WT5qD=Y4D','alichlgref': 'https://we.51job.com/'}# 发送请求detail_res = requests.get(url=detail_url, headers=head, params=params)detail_res.encoding = 'gbk'# 解析请求soup = BeautifulSoup(detail_res.text, 'html.parser')div = soup.find('div', class_='bmsg job_msg inbox')post_dict['工作详细要求'] = div.text.strip()# 将字典添加到列表中post_list.append(post_dict)print(f'第{page}页爬取成功!')
print(post_list)

请各位大佬帮我 解疑释惑!!

51job爬虫的一些问题相关推荐

  1. 51job爬虫-xpath

    51job,爬虫 https://search.51job.com/list/180200,000000,0000,32,9,99,%25E5%2589%258D%25E7%25AB%25AF%25E ...

  2. 前程无忧51job爬虫利用selenium爬取岗位信息-2021年10月29日

    # 2021年10月29日完成,爬取51job网站获得相关岗位信息 from selenium import webdriver from selenium.webdriver import Fire ...

  3. 51JOB爬虫+数据可视化 python

    1.登录模块: 用了Xpath和selenium,最后被缺口滑块验证码反爬了一波,缺口验证码那个地方成功率奇低. from selenium import webdriver from seleniu ...

  4. 前程无忧51job爬虫

    先知:本程序采集数据仅用于测试,并非商用,如有侵权,请联系本人删除,谢谢. 爬取招聘网站,然后就开始寻找规律,先爬取前程无忧的,请多看看url的变化,有按公司的搜索.有按职位的搜索:页码也是有规律的变 ...

  5. Python网络爬虫进阶+正则表达式

    1 HTML基础 1.1 HTML结构 1.2 HTML各标签结构 1.3 HTML样式 2.正则表达式 2.1 元字符 2.1.1 元字符之. ^ $ * + ? { } 2.1.2 元字符之字符集 ...

  6. 视频教程-Python数据分析与爬虫-Python

    Python数据分析与爬虫 10年一线开发及项目管理经验,6年以上大数据项目架构.实施.开发与运维经验,骨灰级大数据玩家,对Hadoop.Storm.Spark.Flink.Kylin.Druid等大 ...

  7. Python-51job爬虫

    文章目录 前言 一.模块使用 二.数据的爬取与建立url列表 1.获取所有网页详情页链接 2.获取详情页html源码并筛选我们需要的信息 3.提取信息进行excel本地保存 1.Excel结果展示 总 ...

  8. 抓取前程无忧招聘信息

    抓取前程无忧招聘信息 本文通过分析前程无忧的相关规则,通过python来抓取相关的招聘信息,并通过redis缓存相关信息,实现增量抓取. 相关技术 python3.6 requests redis m ...

  9. 怎么防爬虫爬取信息_scrapy爬取51job职位信息(针对新的反爬虫机制)!

    1 定义抓取内容 在items.py中添加如下代码: class Job51Item(scrapy.Item):title = scrapy.Field()salary = scrapy.Field( ...

  10. python爬虫之51job工作搜索

    简介   大多数情况下我们通过urllib2等模块可以对单纯的html进行爬取分析,但是当我们遇到的页面是js渲染的,我们需要去分析一个一个后台的请求,这就太蛋疼了.若我们使用像浏览器一样的工具来处理 ...

最新文章

  1. 基于Ubuntu交叉编译FFmpeg Windows SDK
  2. windows默认共享的打开和关闭?
  3. Day8 Python基础之遗漏知识点(六)
  4. Android开发工具之Android Studio--如何打包sdk通过arr包的方式
  5. 查看Tomcat版本及多版本切换
  6. HDU - 1584 蜘蛛牌(dfs+最优性剪枝)
  7. Android里的shell的系统命令
  8. [渝粤教育] 中国地质大学 马克思主义基本原理 复习题
  9. hbase多master和动态添加节点
  10. hashmap put方法_Java HashMap put()方法与示例
  11. Spring事务管理知识概述
  12. oracle 9i手动启动数据库,Oracle9iAS (之五): 手工起动,关闭系统
  13. 转载关于通过判断浏览器的userAgent,用正则来判断是否是ios和Android客户端
  14. linux流量管家安装失败,解决Linux流量统计软件vnstat安装后无法统计流量的问题...
  15. 软件产品功能思维导图
  16. 计算机怎样把c盘扩大,电脑变卡 原来都是C盘容量惹的祸 简单一招教你如何扩大C盘容量...
  17. php linux 一键部署工具,Linux一键配置工具ezhttp介绍
  18. 单片机推挽输出c语言,单片机IO口科普:推挽输出、开漏输出详解
  19. codeforces水题100道 第九题 Codeforces Beta Round #63 (Div. 2) Young Physicist (math)
  20. 魅族便签,是否能成为国内便签应用的No.1?

热门文章

  1. 用python实现将Word文档内的表格变整齐
  2. 为什么微软重视小冰这样的“智能机器人”服务
  3. You can not remove xxxx because its imported as
  4. 晶科科技净利润三连降,靠氢能支撑能否学会独立行走?
  5. 【论文小综】基于外部知识的VQA(视觉问答)
  6. 创建第一个springmvc项目,静态资源的访问
  7. ebay如何通过html上传图片,eBay上传图片要求详解,附图片制作技巧
  8. 聊聊page cache与Kafka之间的事儿
  9. 企业数字化转型,路在何方?
  10. 关于在FF浏览器下, 使用innerHTML获取不到元素值的解决方案