Python 爬虫并且将数据写入Excel

听到网站爬虫,很多人都觉得很高大上,爬虫是不是黑客才能干的事啊?今天这里展示了一个简单的爬虫程序,并且对数据进行读取分析,最后写入Excel文件。

难点在于分析HTML代码上,最起码您得看得懂HTML代码。

requests库

requests库功能很强大,这里我们需要用到它都只是我们给它一个网址,然后让它将html代码获取下来:

import requests

headers = {
    'User-Agent': 'Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.100 Mobile Safari/537.36'}
r = requests.get('http://www.baidu.com', headers=headers)
print(r.text)

有些网站含有防爬虫机制,如果不设置UserAgent就无法获取准确的网站内容。那么该如何取得User-Agent到值:

如果你使用到送chrome浏览器,那么按F12,然后再刷新页面,在Network页面中选择all,再在左侧到www.baidu.com中找到Headers中找出User-Agent复制即可,其它网页也是类似操作。

image-20200213153036379.png

运行之后将会得到baidu.com首页都全部代码:(代码太长,此处省略)

提取HTML数据:Beautiful Soup

Beautiful Soup 是一个可以从HTML或XML文件中提取数据的Python库.它能够通过你喜欢的转换器实现惯用的文档导航,查找,修改文档的方式.Beautiful Soup会帮你节省数小时甚至数天的工作时间.

好,现在查阅了Beautiful Soup官网都基本说明,我们可以来完成一个最简单都爬虫代码,获取到百度的title值:

import requests
from bs4 import BeautifulSoup

headers = {
    'User-Agent': 'Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.100 Mobile Safari/537.36'}
r = requests.get('http://www.baidu.com', headers=headers)
soup = BeautifulSoup(r.text, 'html.parser')
pagetitle = soup.find("title")
print(pagetitle.get_text())

运行以后得到:

百度一下

进程已结束,退出代码 0

其实还是相当简单的对吧,下面我们再把难度提高一点点,去获取一个复杂点都网站,并且把它写入Excel文件里面。

爬虫实行僧网站

下面到例子是爬取实习僧网站,是一个实习生的招聘网站。

我们想爬取到是从page=1-page=4之间的所有页面,即是从:

https://www.shixiseng.com/interns?page=1&keyword=python

https://www.shixiseng.com/interns?page=4&keyword=python

之间的所有网页:

那么按照上面的代码,我们可以写出以下的代码:

import requests

htmls = []
headers = {
    'User-Agent': 'Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.100 Mobile Safari/537.36'}
for page in range(1, 5):
    url = f'https://www.shixiseng.com/interns?page={page}&keyword=python'
    r = requests.get(url, headers=headers)
    htmls.append(r.text)
    print('正在读取的页面:' + url)

D:\python_pycharm\pro\venv\Scripts\python.exe D:/python_pycharm/pro/pachong2.py
正在读取的页面:https://www.shixiseng.com/interns?page=1&keyword=python
正在读取的页面:https://www.shixiseng.com/interns?page=2&keyword=python
正在读取的页面:https://www.shixiseng.com/interns?page=3&keyword=python
正在读取的页面:https://www.shixiseng.com/interns?page=4&keyword=python

进程已结束,退出代码 0

看着屏幕逐渐跳出正在读取的页面的URL,其实是很有感觉的~~

接着,我们对页面到HTML代码进行分析:

image-20200214164309764.png

根据图片我们可以看出,左侧到列表是在<div class="intern-wrap intern-item" 里面,那么首先我们需要获取到这个类别里面的代码就可以,做一个循环,将所有的列表先找出来。可以用下面的代码来

headers = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/82.0.4051.0 Safari/537.36 Edg/82.0.425.0'}
for page in range(1, 2):
    url = f'https://www.shixiseng.com/interns?page={page}&keyword=python&city=%E5%85%A8%E5%9B%BD&internExtend='
    r = requests.get(url)
    soup = BeautifulSoup(r.text, 'lxml')
    offers = soup.select('.intern-wrap.intern-item')
    htmls = []
    for offer in offers:

但我们主要不是找列表的所有数据,我们根据需求获取其中一部分的数据即可。假设我们需要提取的是职位名称,就是上图的 开发部-Python实习生(此处有反爬虫机制,数字和字母都使用了一种特殊的字体进行简单的加密,如果需要正确读取需要进行解密,等以后再写一篇文章说明)和详细页面的链接即可。

循环获取到列表数据以后,我们再获取所需要的数据,分析代码我们看到,标题和链接的html代码是:

<div class="f-l intern-detail__job" data-v-6dc0c1eb=""><p data-v-6dc0c1eb=""><a href="https://www.shixiseng.com/intern/inn_rgbpqean65ke" title="深度学习培训导&amp;#xf34e实习&amp;#xe1ba" target="_blank" class="title ellipsis font" data-v-6dc0c1eb="">深度学习培训导实习</a> <!----> <span class="day font" data-v-6dc0c1eb="">-/天</span></p> <p class="tip" data-v-6dc0c1eb=""><span class="city ellipsis" data-v-6dc0c1eb="">上海</span> <span data-v-6dc0c1eb="">|</span> <span class="font" data-v-6dc0c1eb="">天/周</span> <span data-v-6dc0c1eb="">|</span> <span class="font" data-v-6dc0c1eb="">个月</span></p></div>

我们要如何查询这一段代码的需要内容呢,首先要得到链接,就要让指针指向div - class='intern-detail__job'里面,再查找a标签里面的href即可得到url,利用get_text()就可以得到名称(本例中的title也是可以的)

htmls = []
for offer in offers:
    urls = offer.find('div', class_="intern-detail__job").find("p").find("a")
    name = urls.get_text()
    link = urls["href"]
    htmls.append(
        {'name': name, 'url': link})

现在我们先不着急着把数据写入Excel,先把数据写入字典htmls=[]里面,再打印出来。如果查找不对,那么将打印出一个空的字典出来,完整代码如下:

import requests
from bs4 import BeautifulSoup

headers = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/82.0.4051.0 Safari/537.36 Edg/82.0.425.0'}
for page in range(1, 2):
    url = f'https://www.shixiseng.com/interns?page={page}&keyword=python&city=%E5%85%A8%E5%9B%BD&internExtend='
    r = requests.get(url)
    soup = BeautifulSoup(r.text, 'lxml')
    offers = soup.select('.intern-wrap.intern-item')
    htmls = []
    for offer in offers:
        urls = offer.find('div', class_="intern-detail__job").find("p").find("a")
        name = urls.get_text()
        link = urls["href"]
        htmls.append(
            {'name': name, 'url': link})
    print('正在读取的页面:' + url)
    print(htmls)

程序输出:

正在读取的页面:https://www.shixiseng.com/interns?page=1&keyword=python&city=%E5%85%A8%E5%9B%BD&internExtend=
[{'name': '数据科学实习\ue1ba', 'url': 'https://www.shixiseng.com/intern/inn_j34ozcntlsab'}, {'name': '\ue62b\uf1dd\uf040\ue43a\uede0\uf6c5运维实习\ue1ba', 'url': 'https://www.shixiseng.com/intern/inn_i3dkjet1hnbn'}, {'name': '售\uf8bd实习\ue1ba', 'url': 'https://www.shixiseng.com/intern/inn_ghmrjov3g75r'}, {'name': '【\uedbf\uf2ae\uedbf\uf2ae校\ue5e8】后台 开发\uf31e\ueeea\uf34e', 'url': 'https://www.shixiseng.com/intern/inn_ibdhjujc1r7j'}, {'name': '【\uedbf\uf2ae\uedbf\uf2ae校\ue5e8】爬虫\uf31e\ueeea\uf34e', 'url': 'https://www.shixiseng.com/intern/inn_rcsmiygwdwzp'}, {'name': '服务\ued26开发实习\ue1ba', 'url': 'https://www.shixiseng.com/intern/inn_ok5wfm0zjaru'}, {'name': '\ue62b\uf1dd\uf040\ue43a\uede0\uf6c5开发实习\ue1ba-\uf3c6\ue147团队', 'url': 'https://www.shixiseng.com/intern/inn_zo0olj4az7xo'}, {'name': '\ue62b\uf1dd\uf040\ue43a\uede0\uf6c5开发\uf31e\ueeea\uf34e', 'url': 'https://www.shixiseng.com/intern/inn_otbcbdcmlfrv'}, {'name': ' 编\ueeea讲\uf34e--\uedbf\uf2ae届校\ue5e8', 'url': 'https://www.shixiseng.com/intern/inn_eogiclckforz'}, {'name': '后\ued26开发实习\ue1ba', 'url': 'https://www.shixiseng.com/intern/inn_njckxepejl1q'}, {'name': '深度学习培训导\uf34e实习\ue1ba', 'url': 'https://www.shixiseng.com/intern/inn_rgbpqean65ke'}, {'name': '\ue62b\uf1dd\uf040\ue43a\uede0\uf6c5实习\ue1ba', 'url': 'https://www.shixiseng.com/intern/inn_bfom7ajdvvsz'}, {'name': '\ue62b\uf1dd\uf040\ue43a\uede0\uf6c5实习', 'url': 'https://www.shixiseng.com/intern/inn_kabgjlwc9tmc'}, {'name': '\ue62b\uf1dd\uf040\ue43a\uede0\uf6c5助教实习\ue1ba', 'url': 'https://www.shixiseng.com/intern/inn_eewbvqvs3no1'}, {'name': '数据分析实习\ue1ba', 'url': 'https://www.shixiseng.com/intern/inn_ckb0bj41ti5t'}, {'name': '金融\uf31e\ueeea实习\ue1ba', 'url': 'https://www.shixiseng.com/intern/inn_seknmdkmqfp6'}, {'name': '\ue62b\uf1dd\uf040\ue43a\uede0\uf6c5爬虫\uf31e\ueeea\uf34e', 'url': 'https://www.shixiseng.com/intern/inn_gybdr3swa1nz'}, {'name': '数据清洗\uf31e\ueeea\uf34e', 'url': 'https://www.shixiseng.com/intern/inn_110d5rowipjl'}, {'name': '\ue62b\uf1dd\uf040\ue43a\uede0\uf6c5 后\ued26开发实习\ue1ba', 'url': 'https://www.shixiseng.com/intern/inn_m97hnb9uidsy'}, {'name': '\ue62b\uf1dd\uf040\ue43a\uede0\uf6c5助教', 'url': 'https://www.shixiseng.com/intern/inn_4pbllbmzn0kx'}, {'name': '\ue62b\uf1dd\uf040\ue43a\uede0\uf6c5开发实习', 'url': 'https://www.shixiseng.com/intern/inn_xp0f1iwabrzv'}]

字典有数据,并且符合我们的要求,写入成功。

将数据写入Excel

写入Excel也很简单,今天我们来安装一个新的Excel库:openpyxl。

然后在代码的文件夹中新建一个Excel文件,取名为list1.xlsx,那么要写入这个文件的代码是:

from openpyxl import load_workbook

workbook = load_workbook(filename='list1.xlsx')
sheet = workbook.active

那么插入数据的方法有很多,下面我们看最简单的方法,在循环的内部插入代码:

import requests
from bs4 import BeautifulSoup
from openpyxl import load_workbook

workbook = load_workbook(filename='list1.xlsx')
sheet = workbook.active
I = 0
headers = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/82.0.4051.0 Safari/537.36 Edg/82.0.425.0'}
for page in range(1, 5):
    url = f'https://www.shixiseng.com/interns?page={page}&keyword=python&city=%E5%85%A8%E5%9B%BD&internExtend='
    r = requests.get(url)
    soup = BeautifulSoup(r.text, 'lxml')
    offers = soup.select('.intern-wrap.intern-item')
    for offer in offers:
        I += 1
        urls = offer.find('div', class_="intern-detail__job").find("p").find("a")
        name = urls.get_text()
        link = urls["href"]
        str1 = 'A' + str(I)
        str2 = 'B' + str(I)
        sheet[str1].value = name
        sheet[str2].value = link
    print('正在读取的页面:' + url)
workbook.save(filename='list1.xlsx')

打开list1.xlsx文件,写入成功:

image-20200218150924500.png

可以看到,name的输出有一些打不出来,因为该网站对字母和数字和一些常用汉字做了反爬虫加密,例如A4A5,原标题是:【2020校招】。只要将加密的字符提取出来,并且做个查询就可以反向得到正确的字符,这方面的知识等以后有时间再写写。这里只是写出爬虫、并且将爬虫数据写入Excel文件的一个简单思路。对自己来说是个备忘作用,如果刚好对您有所帮助,那就再好不过了。

requests库功能很强大,下一步我希望能做出自动登录-登录以后自动完成一些工作,这才是我需要的功能!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 221,273评论 6 515
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,349评论 3 398
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 167,709评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,520评论 1 296
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,515评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,158评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,755评论 3 421
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,660评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,203评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,287评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,427评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,122评论 5 349
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,801评论 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,272评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,393评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,808评论 3 376
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,440评论 2 359

推荐阅读更多精彩内容