首页 > 编程语言 > 详细

简单python爬虫练习 E站本爬取

时间:2020-05-01 23:55:12      阅读:193      评论:0      收藏:0      [点我收藏+]

必备条件:

一台能上404的机子..

过程:

翻本子的时候觉得要是直接爬到本地看起来多舒服啊..然后就写了个爬虫,由于也只是初学爬虫,个中技巧也不熟练,写的过程中的语法用法参考了很多文档和博客,我是对于当前搜索页用F12看过去..找到每个本子的地址再一层层下去最后下载图片...然后去根据标签一层层遍历将文件保存在本地,能够直接爬取搜索页下一整页的所有本,并保存在该文件同级目录下,用着玩玩还行中途还被E站封了一次IP,一看起来就觉得写的属实差劲(差就是还有进步空间嘛
技术分享图片
技术分享图片
技术分享图片
这就是个试验页 别想太多

代码:

from bs4 import BeautifulSoup
import re
import requests
import os
import urllib.request

headers = {
    ‘User-Agent‘: ‘Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.82 Safari/537.36‘,
    ‘Accept‘: ‘text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8‘,
    ‘Upgrade-Insecure-Requests‘: ‘1‘}
r = requests.get("https://e-hentai.org/", headers=headers)
soup = BeautifulSoup(r.text, ‘lxml‘)
divs = soup.find_all(class_=‘gl3c glname‘)
# 爬取当前页面的本子网址
for div in divs:
    url = div.a.get(‘href‘)
    r2 = requests.get(url, headers=headers)
    soup2 = BeautifulSoup(r2.text, ‘lxml‘)
    manga = soup2.find_all(class_=‘gdtm‘)
    title = soup2.title.get_text()  # 获取该本子标题
    # 遍历本子的各页
    for div2 in manga:
        picurl = div2.a.get(‘href‘)
        picr = requests.get(picurl, headers=headers)
        soup3 = BeautifulSoup(picr.text, ‘lxml‘)
        downurl = soup3.find_all(id=‘img‘)
        page = 0
        for dur in downurl:
            # print(dur.get(‘src‘))
            # 判断是否存在该文件夹
            purl=dur.get(‘src‘)
            fold_path = ‘./‘+title
            if not os.path.exists(fold_path):
                print("正在创建文件夹...")
                os.makedirs(fold_path)
            print("正在尝试下载图片....:{}".format(purl))
            #保留后缀
            filename = title+str(page)+purl.split(‘/‘)[-1]
            filepath = fold_path + ‘/‘ + filename
            page = page + 1
            if os.path.exists(filepath):
                print("已存在该文件,不下了不下了")
            else:
                try:
                    urllib.request.urlretrieve(purl, filename=filepath)
                except Exception as e:
                    print("error发生:")
                    print(e)

简单python爬虫练习 E站本爬取

原文:https://www.cnblogs.com/graytido/p/12815423.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!