爬虫抓取51job软件测试页面上 某公司名称 python实现

本文介绍了如何使用Python爬虫抓取51job网站上特定公司的软件测试职位信息,旨在学习调用父类的方法。通过spider1.py、spider2.py和spider3.py的代码示例,展示了如何设置和传递URL参数。
摘要由CSDN通过智能技术生成

#需求:抓取51job软件测试页面上 某公司名称
主要用来学习调用父类

spider1.py

import requests
class spider():
    def __init__(self):
        self.headers={"user-agent":"Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.149 Safari/537.36"}
    def submit(self,url):
        response=requests.get(url,self.headers)
        response.encoding = "gbk"
        return response.text

if __name__=="__main__":
    obj=spider()
    res=obj.submit("https://www.51job.com")
    print(res)

spider2.py
spider2里只在初始化方法里加了url参数,只为学习调用父类使用,将url直接写在spider1的初始化里更为合适

#51job网页 搜索软件测试的界面,用子类调用父类的属性和方法
import requests
from Spider.spiderV1 import spider

class spiderV2(spider):
    def __init__(self,url):  #--url是变量
        self.url2=url         #--self.url2 是属性
        spider.__init__(self)

if __name__=='__main__':
    u="https://search.51job.com/list/080300,000000,0000,00,9,99,%25E8%25BD%25AF%25E4%25BB%25B6%25E6%25B5%258B%25E8%25AF%2595,2,1.html?lang=c&stype=&postchannel=0000&workyear=99&cotype=99&degreefrom=99&jobterm=99&companysize=99&providesalary=99&lonlat=0%2C0&radius=-1&ord_field=0&confirmdate=9&fromType=&dibiaoid=0&address=&line=&specialarea=00&from=&welfare="
    obj=spiderV2(u)      #--u 是变量
    res=obj.submit(obj.url2)     #-- url2是属性   **对象后面可以点属性/方法,不能点变量
    print(res)

spider3.py

import requests
from lxml import etree
from Spider.spiderV2 import spiderV2

class spiderV3(spiderV2):
    def __init__(self):
        spiderV2.__init__(self,u)
    def position(self,spage):
        dic={}
        document=etree.HTML(spage)
        ele=document.xpath('//*[@id="resultList"]/div[4]/span[1]/a/text()')
        dic=['公司名:',ele]
        return dic
    def savedata(self,d):
        with open("company.txt","w") as file:
            file.write(str(d))

if __name__=="__main__":
    u="https://search.51job.com/list/080300,000000,0000,00,9,99,%25E8%25BD%25AF%25E4%25BB%25B6%25E6%25B5%258B%25E8%25AF%2595,2,1.html?lang=c&stype=&postchannel=0000&workyear=99&cotype=99&degreefrom=99&jobterm=99&companysize=99&providesalary=99&lonlat=0%2C0&radius=-1&ord_field=0&confirmdate=9&fromType=&dibiaoid=0&address=&line=&specialarea=00&from=&welfare="
    obj3=spiderV3()
    obj3.url3=u
    res=obj3.submit(obj3.url3)
    pos=obj3.position(res)
    print(pos)
    obj3.savedata(pos)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值