色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

python使用requests庫爬取拉勾網(wǎng)招聘信息的實現(xiàn)

瀏覽:11日期:2022-07-04 16:57:42

按F12打開開發(fā)者工具抓包,可以定位到招聘信息的接口

python使用requests庫爬取拉勾網(wǎng)招聘信息的實現(xiàn)

在請求中可以獲取到接口的url和formdata,表單中pn為請求的頁數(shù),kd為關請求職位的關鍵字

python使用requests庫爬取拉勾網(wǎng)招聘信息的實現(xiàn)

python使用requests庫爬取拉勾網(wǎng)招聘信息的實現(xiàn)

使用python構建post請求

data = { ’first’: ’true’, ’pn’: ’1’, ’kd’: ’python’}headers = { ’referer’: ’https://www.lagou.com/jobs/list_python/p-city_0?&cl=false&fromSearch=true&labelWords=&suginput=’, ’user-agent’: ’Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.198 Safari/537.36’}res = requests.post('https://www.lagou.com/jobs/positionAjax.json?needAddtionalResult=false', data=data,headers=headers)print(res.text)

發(fā)現(xiàn)沒有從接口獲取到數(shù)據(jù)

python使用requests庫爬取拉勾網(wǎng)招聘信息的實現(xiàn)

換了個網(wǎng)絡后接口還是會返回操作頻繁的錯誤信息,仔細檢查后發(fā)現(xiàn)這個接口需要一個動態(tài)的cookies不然會一值返回錯誤頻繁

data = { ’first’: ’true’, ’pn’: ’1’, ’kd’: ’python’}#頭部中必須有user-agent和referer不然不會返回cookiesheaders = { ’referer’: ’https://www.lagou.com/jobs/list_python/p-city_0?&cl=false&fromSearch=true&labelWords=&suginput=’, ’user-agent’: ’Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.198 Safari/537.36’}#通過訪問主頁獲取cookiesr1= requests.get('https://www.lagou.com/jobs/list_python/p-city_0?&cl=false&fromSearch=true&labelWords=&suginput=’',headers=headers)#再post請求中傳入cookiesr2 = requests.post('https://www.lagou.com/jobs/positionAjax.json?needAddtionalResult=false', data=data,headers=headers, cookies=r2.cookies)print(r2.text)

注意!每請求十次接口cookies也會刷新一次,下面貼上完整爬蟲代碼

import jsonimport loggingimport requests#獲取cookiedef getCookie(): res = requests.get('https://www.lagou.com/jobs/list_python/p-city_0?&cl=false&fromSearch=true&labelWords=&suginput=',headers=headers) return res.cookies#獲取json數(shù)據(jù)def getPage(i, cookies, kw): data = { ’first’: ’true’, ’pn’: i, ’kd’: kw } res = requests.post('https://www.lagou.com/jobs/positionAjax.json?needAddtionalResult=false', data=data, headers=headers, cookies=cookies) return json.loads(res.text)#合并列表def reduceList(l): text = '' for i in l: text += i + ' ' return text.strip()#提取字段并保存到文件中def saveInCsv(f, data): js = data['content']['positionResult']['result'] for node in js: # 對空值進行處理 district = node['district'] if district != None: district = '-' + district else: district = '' f.write( node['positionName'] + '·' + node['city'] + district + '·' + node['salary'] + '·' + node['workYear'] + '·' + node['education'] + '·' + reduceList(node['skillLables']) + '·' + node['companyShortName'] + '·' + node['companySize'] + '·' + node['positionAdvantage'] + 'n')if __name__ == ’__main__’: #定義頭部 headers = { ’referer’: ’https://www.lagou.com/jobs/list_python/p-city_0?&cl=false&fromSearch=true&labelWords=&suginput=’, ’user-agent’: ’Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.198 Safari/537.36’ } #初始化cookie cookies = getCookie() with open('file.csv', 'w', encoding='utf-8') as f: for i in range(1, 31): #每十個請求重新獲取cookie if (i % 10 == 0):cookies = getCookie() #解析字段并存儲 data = getPage(i, cookies, 'python') saveInCsv(f, data)

到此這篇關于python使用requests庫爬取拉勾網(wǎng)招聘信息的實現(xiàn)的文章就介紹到這了,更多相關python requests爬取拉勾網(wǎng)內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 国产美女动态免费视频 | 97在线公开视频 | 全高清特级毛片 | 欧美日韩一区二区三区视频播 | 欧美激情精品久久久久久久久久 | 手机看片日本 | 国产精品一区伦免视频播放 | 婷婷在线成人免费观看搜索 | 亚洲视频在线免费看 | 国产高清在线精品免费 | 国产在线精品福利一区二区三区 | 亚洲欧美v视色一区二区 | 久久高清一级毛片 | 国产精品欧美日韩一区二区 | 国产真实乱子伦精品视手机观看 | 国产成人免费观看在线视频 | 大陆孕妇孕交视频自拍 | 日本精品视频一区二区三区 | 亚洲国产天堂久久精品网 | 日韩欧一级毛片在线播无遮挡 | 国产人人插 | 精品一精品国产一级毛片 | 免费日韩在线视频 | 亚洲国产99在线精品一区二区 | 精品成人 | 欧美精品亚洲人成在线观看 | 久久91精品国产一区二区 | 国产成人精品综合 | 久久91精品国产99久久yfo | 久久黄色精品视频 | 一级做α爱过程免费视频 | 成人精品一区久久久久 | 久久久毛片 | 久久精品在 | 国产成人美女福利在线观看 | 九九久久精品视频 | 国产欧美日韩高清专区手机版 | 色综合久久91 | 手机看片神马午夜片 | 一级片aaa | 国产成a人亚洲精v品久久网 |