欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

python爬虫判断招聘信息是否存在的实例代码

程序员文章站 2022-04-21 19:14:51
在找工作的时候,我们会选择上网查询招聘的信息,或者是通过一些招聘会进行现场面试。但由于信息更新不及时,有一些岗位会出现下架的情况,如果我们不注意的话,可能就扑了空。在时间上耽误了不说,面试的信息也会受...

在找工作的时候,我们会选择上网查询招聘的信息,或者是通过一些招聘会进行现场面试。但由于信息更新不及时,有一些岗位会出现下架的情况,如果我们不注意的话,可能就扑了空。在时间上耽误了不说,面试的信息也会受到一点点打击。今天小编就教大家python爬虫来判断招聘信息是否存在。

首先这里需要一个判断某条招聘是否还挂在网站上的方法,这个暂时想到了还没弄,然后对于发布时间在两个月之前的数据,就不进行统计计算。

以下是完成代码:

{
  "_id" : objectid("5a30ad2068504386f47d9a4b"),
  "city" : "苏州",
  "companyshortname" : "蓝海彤翔",
  "companysize" : "100-499人",
  "education" : "本科",
  "financestage" : "b轮",
  "industryfield" : "互联网",
  "level" : 3,
  "pid" : "11889834",
  "positionlables" : [
    "php",
    "thinkphp"
  ],
  "positionname" : "php研发工程师",
  "salary" : {
    "avg" : 7500.0,
    "low" : 7000,
    "high" : 8000
  },
  "time" : "2017-06-06",
  "updated_at" : "2017-12-13 18:31:15",
  "workyear" : "1-3年",
  "detail" : "1、处理landcloud云计算相关系统的各类开发和调研工作;2、处理coms高性能计算的各类开发和调研工作岗位要求:1、本科学历,两年以上工作经验,熟悉php开发,了解常用的php开发技巧和框架;2、了解c++,python及java开发;3、有一定的研发能力和钻研精神;4、有主动沟通能力和吃苦耐劳的精神。",
  "location" : "苏州市高新区科技城锦峰路158号101park8幢"

实例扩展:

python爬虫爬取腾讯招聘信息 (静态爬虫)

import requests
from bs4 import beautifulsoup
from math import ceil

header = {
  'user-agent': 'mozilla/5.0 (windows nt 6.1; wow64) applewebkit/537.36 (khtml, like gecko) chrome/67.0.3396.99 safari/537.36'}


# 获取岗位页数
def getjobpage(url):
  ret = requests.get(url, headers=header)
  ret.encoding = "utf-8" # 解决乱码问题
  html = ret.text
  soup = beautifulsoup(html, 'html.parser')
  # 获取岗位总数,< span class ="lightblue total" > 512 < / span >
  totaljob = soup.select('span[class="lightblue total"]')[0].text
  jobpage = ceil(int(totaljob) / 10)
  return jobpage


def getjoborder(url):
  ret = requests.get(url, headers=header)
  ret.encoding = "utf-8" # 解决乱码问题
  html = ret.text
  soup = beautifulsoup(html, 'html.parser')
  # 工作职责
  jobrequests = soup.select('ul[class="squareli"]')[0].text
  # 工作要求
  joborder = soup.select('ul[class="squareli"]')[1].text
  return jobrequests, joborder


# 获取岗位信息
def getjobinfo(url):
  myfile = open("tencent_job.txt", "a", encoding='gb18030', errors='ignore') # 解决乱码问题
  ret = requests.get(url, headers=header)
  ret.encoding = "utf-8" # 解决乱码问题
  html = ret.text
  soup = beautifulsoup(html, 'html.parser')
  joblist = soup.find_all('tr', class_=['even', 'odd'])
  for job in joblist:
    # url
    joburl = "https://hr.tencent.com/" + job.select('td:nth-of-type(1) > a')[0]['href']
    # 职位名称
    jobname = job.select('td:nth-of-type(1) > a')[0].text
    # 人数
    jobpeople = job.select('td:nth-of-type(3)')[0].text
    # 地点
    jobaddre = job.select('td:nth-of-type(4)')[0].text
    # 发布时间
    jobtime = job.select('td:nth-of-type(5)')[0].text
    # 工作职责
    jobrequests = getjoborder(joburl)[0]
    # 工作要求
    joborder = getjoborder(joburl)[1]

    #print(jobname, joburl, jobaddre, jobpeople, jobtime, jobrequests, joborder)

    tt = jobname + " " + joburl + " " + jobaddre + " " + jobpeople + " " + jobtime + " " + jobrequests + " " + joborder
    myfile.write(tt + "\n")


if __name__ == '__main__':
  mainurl = 'https://hr.tencent.com/position.php?keywords=python'
  jobpage = getjobpage(mainurl)
  print(jobpage)
  for page in range(jobpage):
    pageurl = 'https://hr.tencent.com/position.php?keywords=python&start=' + str(page * 10) + '#a'
    print("第" + str(page + 1) + "页")
    getjobinfo(pageurl)

到此这篇关于python爬虫判断招聘信息是否存在的实例代码的文章就介绍到这了,更多相关python判断招聘信息的存在内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!