吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1947|回复: 11
收起左侧

[Python 原创] 小说爬虫

  [复制链接]
XCHLX 发表于 2023-6-2 14:11
本帖最后由 XCHLX 于 2023-6-2 15:37 编辑

[Python] 纯文本查看 复制代码
import requests  # 导入requests包
from bs4 import BeautifulSoup
import my_fake_useragent as ua
import json
from lxml import etree


class BiQuGe(object):

    def __init__(self):
        self.proxies = None  # 代{过}{滤}理
        self.header = None  # 请求头
        self.set_proxies()

    # 搜索小说
    def get_book(self, searchKey):
        try:
            text = self.geturl(("http://www.xsbiquge.org/search?searchkey=" + searchKey))
            if text is None:
                return []
            bookList = []
            searchHtml = etree.HTML(text)
            searchList = searchHtml.xpath('//*[@class="category-div"]')
            for i in searchList:
                bookList.append({"title": self.getstr(i.xpath('div/div/a/h3/text()')),
                                 "img": self.getstr(i.xpath('a/img/@data-original')),
                                 "path": self.getstr(i.xpath('a/@href')),
                                 "abt": self.getstr(i.xpath('div/div/span/text()')),
                                 "desc": self.getstr(i.xpath('div/div[contains(@class,"intro")]/text()')),
                                 })
            return bookList
        except Exception as e:
            self.del_proxies()
            return None

    # 获取小说目录
    def get_directory(self, dir, currentPage=1, pageSize=500):
        try:
            text = self.geturl(("http://www.xsbiquge.org" + dir))
            if text is None:
                return []
            dirList = []
            searchHtml = etree.HTML(text)

            searchList = searchHtml.xpath('//div[contains(@class,"flex-wrap")]')[1].xpath(
                'a[position()<={0} ]'.format(int(currentPage) * pageSize))
            p = ((int(currentPage) - 1) * pageSize)
            searchList = searchList[p:]
            for i in searchList:
                dirList.append({"title": self.getstr(i.xpath('text()')),
                                "path": self.getstr(i.xpath('@href'))})

            return dirList
        except Exception as e:
            self.del_proxies()
            return None

    # 获取章节内容
    def get_content(self, title):
        try:

            text = self.geturl(("http://www.xsbiquge.org" + title))
            if text is None:
                return []
            bs = BeautifulSoup(text, "html.parser")
            contentStr = []
            contentList = bs.find_all(class_="content")[0].find_all("p")
            for item in contentList:
                if len(item.string) > 1:
                    contentStr.append(item.string)
            self.r.set('xsbiquge', json.dumps(self.proxies), ex=600)
            return contentStr
        except Exception as e:
            self.del_proxies()
            return []

    def get_content_all(self, title):
        try:
            contentStr = []
            contentStr = contentStr + self.get_content(title)
            contentStr = contentStr + self.get_content(title.replace(".html", "_2.html"))
            return contentStr
        except Exception as e:
            return e

    # 重试
    def geturl(self, url):
        text = None
        for i in range(5):
            text = self.__me_post(url)
            if text is not None:
                break
            self.del_proxies()
            self.set_proxies()
        if text is None:
            self.del_proxies()
            print(self.proxies + "失败")
            return None
        else:
            return text

    # 删除失败代{过}{滤}理
    def del_proxies(self):
        pass

    # 设置代{过}{滤}理 和 请求头
    def set_proxies(self):
        self.header = {
            "User-Agent": ua.UserAgent().random(),
        }

# post 请求
    def __me_post(self, url):
        try:
            response = requests.post(url, headers=self.header,
                                     proxies=self.proxies, timeout=1)  # Get方式获取网页数据
            if response.status_code != 200:
                self.del_proxies()
                return None
            else:
                response.encoding = 'utf-8'
                return response.text
        except:
            return None

# get 请求
    def __me_get(self, url):
        response = requests.get(url, headers=self.header,
                                proxies=self.proxies, timeout=1)  # Get方式获取网页数据
        if response.status_code != 200:
            self.del_proxies()
            return None
        else:
            response.encoding = 'utf-8'
            return response.text

# 提取字符串
    def getstr(self, arr):
        if len(arr) > 0:
            return arr[0].strip()
        return None



免费评分

参与人数 1吾爱币 +7 热心值 +1 收起 理由
苏紫方璇 + 7 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

大白baymax 发表于 2023-6-2 14:54
运行出错了
 楼主| XCHLX 发表于 2023-6-2 15:28
皮卡丘2000 发表于 2023-6-2 17:41
dipper 发表于 2023-6-2 18:40
good,try it
 楼主| XCHLX 发表于 2023-6-4 14:27
皮卡丘2000 发表于 2023-6-2 17:41
大佬 运行不起来,直接跳没了

这只是一个工具类  需要自己编写入口调用
皮卡丘2000 发表于 2023-6-5 09:21
XCHLX 发表于 2023-6-4 14:27
这只是一个工具类  需要自己编写入口调用

这这这  还以为能直接用
洞见未来 发表于 2023-6-8 17:01
这个小说站点国内还打不开?
yu520 发表于 2023-6-13 08:45
这个好用,感谢分享
yml264 发表于 2023-6-13 14:18
这个不错,好用。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-11 14:28

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表