吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 11430|回复: 169
收起左侧

[Python 原创] python下载番茄小说爬虫

    [复制链接]
zboi 发表于 2024-3-24 14:10
番茄小说最近应该进行了点更新,导致之前常用下载番茄小说的api失效了,也就是这个 https://novel.snssdk.com/api/novel/book/reader/full/v1 。
我在搜索过程中,在一个油猴脚本中的评论发现了一个新的可以获取番茄小说内容的api,即 http://fq.travacocro.com/content ,不过这个api相对之前的api反应比较慢,因此下载速度也会不如从前。
出处 https://greasyfork.org/zh-CN/scripts/476688-可能失效-番茄全文在线免费读/discussions/235832 。
因此我根据这个api,做了一个番茄小说的下载爬虫,实现番茄小说id下载以及搜索下载。
效果如下:
image.png
搜索功能如上
image.png
输入对应序号既可下载
image.png
下载结束

代码如下:
[Python] 纯文本查看 复制代码
import os
import re
import requests
import time
from os import remove
import aiofiles
from aiohttp import ClientSession, ClientTimeout
import asyncio
from colorama import init
from json import loads


def len_str(string):
    count = 0
    for ch in string:
        if ch >= '\u007f':
            count += 1
    return count


def width(string, length):
    if length < len_str(string):
        return 0
    else:
        return length - len_str(string)


async def fanqie_singe_chapter(id, sem):
    if len(id):
        chapter_url = f'http://fq.travacocro.com/content?item_id={id}'  # 拼接章节网址
        ii = 0
        async with sem:
            while ii < 5:
                ii += 1
                try:
                    timeout = ClientTimeout(total = 50)
                    async with ClientSession(headers = headers1, timeout = timeout) as session:
                        async with session.get(chapter_url) as resp_content:
                            jsons = await resp_content.json()
                            single_content = jsons['data']['data']['content']
                            name2 = jsons['data']['data']['title']
                            async with aiofiles.open(f"./小说/{id}.txt", "w", encoding = "utf-8") as f:  # 在小说目录下创建临时的单章txt
                                await f.write(name2 + '\n\n\n')
                                await f.write(single_content.replace('\n', '\n\n'))
                            print(f'{name2:<{width(name2,60)}}finish')
                            break
                except Exception as e:
                    print(f'{id}     false      {ii}/5')
                    print(e)


# 创建异步任务
async def fanqie_create_tasks(ids, lens):
    tasks = []
    if lens > 100:
        sema = 100
    else:
        sema = lens
    sem = asyncio.Semaphore(sema)
    for id in ids:
        tasks.append(asyncio.create_task(fanqie_singe_chapter(id, sem)))  # 创建任务
    await asyncio.gather(*tasks)


def fanqie_download(book_id):
    if book_id.isdigit():
        time1 = time.time()
        resp_info = requests.get(f'https://fanqienovel.com/page/{book_id}', headers = headers1)
        json1 = loads(re.findall('window.__INITIAL_STATE__=(.*?);', resp_info.text)[0].replace('undefined', 'null'))['page']
        item_ids = json1['itemIds']
        novel_name = json1['bookName']
        novel_author = json1['author']
        if not novel_name:
            print('该书不是正常书籍状态,可能书籍更换了书籍号或者出现了其他原因,内容无法保证正确,请尽量检索完整的小说书名!!')
            novel_name = '异常书籍' + str(book_id)
        else:
            novel_name = novel_name + '-' + novel_author
        if len(item_ids):
            print(f"\033[31m《{novel_name}》({book_id})共{len(item_ids)}章, 开始下载!!\033[0m\n\n")
            item_ids.reverse()
            loop.run_until_complete(fanqie_create_tasks(item_ids, len(item_ids)))  # 提交任务
            time2 = time.time()
            with open(f'./小说/{novel_name}.txt', 'w', encoding = 'utf-8') as f1:  # 将分散的小说章节写入一个{书名}.txt中
                for id in item_ids:
                    try:
                        with open(f'./小说/{id}.txt', 'r', encoding = 'utf-8') as f2:
                            text1 = f2.read()
                            f1.write(text1)
                        remove(f"./小说/{id}.txt")  # 移除已写入{书名}.txt的临时章节
                    except:
                        print(f'{id}  false')
                print('==============================下载完成==============================\n')
            print(f'共耗时:\033[33m{time2 - time1:.2f}s\033[0m\n\n')
            print(f'\033[32m《{novel_name}》已下载!!!!\033[0m\n\n\n')
        else:
            print('\033[31m请输入有效的书籍ID\033[0m\n')
    else:
        print('\033[31m请输入纯数字的书籍ID!!!!\033[0m')


if __name__ == '__main__':
    headers1 = {
        "User-Agent": "Mozilla/5.0 (Linux; Android 10; TAS-AN00 Build/HUAWEITAS-AN00; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/114.0.5735.61 Mobile Safari/537.36 Super 4.6.5"
    }
    init(autoreset = True)
    loop = asyncio.new_event_loop()
    asyncio.set_event_loop(loop)
    strinfo = re.compile('[/:*?"<>|\\\\]')  # 匹配字符串中特殊的字符
    if not os.path.exists("小说"):
        os.mkdir("小说")
    a = input('番茄小说ID下载:    1 \n番茄小说搜索下载:  2 \n请选择:')
    if a == '1':
        print(
            '\n\033[31m注意\033[0m:下载番茄小说的小说,需要自行获取书籍的id,可以通过网页搜索的方式获取\n      就是书籍章节页面url后面那一串数字,输入那一串数字即可\n')
        while True:
            bookid = input('请输入番茄小说ID(批量下载请用空格分割):')
            if bookid:
                for id in bookid.split(' '):
                    fanqie_download(id)
                    time.sleep(0.5)
    elif a == '2':
        print('\n\033[31m番茄小说搜索下载功能\033[0m:尽量检索完整小说书名,可能会出现正常网页检索不出的书籍,请注意甄别')
        while True:
            search_name = input('请输入书名或者作者名进行搜索:')
            book_id, num = [], 0
            for i in range(3):
                new_url = f'https://novel.snssdk.com/api/novel/channel/homepage/search/search/v1/?device_platform=android&parent_enterfrom=novel_channel_search.tab&aid=1967&offset={i * 10}&q={search_name}'
                for _ in range(3):
                    resp = requests.get(url = new_url, headers = headers1).json()
                    if resp['message'] == 'success':
                        break
                    else:
                        time.sleep(1)
                if resp['message'] != 'success':
                    print(resp['message'])
                    continue
                for book in resp['data']['ret_data']:
                    if book['author'] == '番茄漫画' or book['author'] == '番茄畅听':
                        continue
                    else:
                        book_id.append(book['book_id'])
                        title, author = book['title'], book['author']
                        num += 1
                        print(f'{num:<4}{title:^{width(title, 60)}}{author:<{width(author, 40)}}')
                if not resp['data']['has_more']:
                    break
            choose = input('请输入书籍序号,输入\033[32m0\033[0m重新搜索(批量下载请用空格分割序号):')
            choose_list = choose.split(' ')
            for ids in choose_list:
                if ids.isdigit():
                    if int(ids) <= len(book_id):
                        if int(ids):
                            fanqie_download(book_id[int(ids) - 1])
                            time.sleep(0.5)
                        else:
                            continue
                    else:
                        print('\033[31m序号超出范围,请重新搜索!!\033[0m')
                else:
                    print('\033[31m请输入正确格式的书籍序号!!!!\033[0m')

免费评分

参与人数 42吾爱币 +43 热心值 +33 收起 理由
joeredhair + 1 谢谢@Thanks!
poiuyhn + 1 谢谢@Thanks!
lanrena + 1 + 1 热心回复!
feng8023lin + 1 + 1 鼓励转贴优秀软件安全工具和文档!
Elphelt + 1 谢谢@Thanks!
umena + 1 + 1 我很赞同!
wsx27 + 1 谢谢@Thanks!只是已经失效了。
小猩猩 + 1 感谢,只是现在已经失效了
sangmili + 1 谢谢@Thanks!
75380417 + 1 + 1 谢谢@Thanks!
寻找乐趣 + 1 + 1 我很赞同!
asddp + 1 + 1 谢谢@Thanks!
maybe1229 + 1 谢谢@Thanks!
echoaku + 1 + 1 热心回复!
Mirro_r + 1 + 1 谢谢@Thanks!
不知火龙果 + 1 + 1 感谢分享
fyzhai + 1 + 1 谢谢@Thanks!
yuchus + 1 + 1 我很赞同!
Li668 + 1 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
xx777521 + 1 + 1 谢谢@Thanks!
billkeyjian + 1 谢谢@Thanks!
小邑走天下 + 1 + 1 我很赞同!
whanlm + 1 + 1 谢谢@Thanks!
j37162960 + 1 + 1 谢谢@Thanks!
zswlhw + 1 谢谢@Thanks!
ui1840 + 1 + 1 谢谢@Thanks!
xun001 + 1 + 1 谢谢@Thanks!
liuyunak + 1 谢谢@Thanks!
PhiFever + 1 + 1 谢谢@Thanks!
微风起的吾爱 + 1 + 1 我很赞同!
soughing + 1 + 1 我很赞同!
usignolosu + 1 + 1 谢谢@Thanks!
zhu1979 + 1 + 1 谢谢@Thanks!
zzspangle + 1 谢谢@Thanks!
fjkss + 1 + 1 我很赞同!
苏紫方璇 + 7 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!
lin_xop + 1 + 1 热心回复!
Zimno + 1 + 1 谢谢@Thanks!
shanzhanzhe + 1 + 1 谢谢@Thanks!
xk520 + 1 感谢分享
Xubh + 1 谢谢@Thanks!
hefan8 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!

查看全部评分

本帖被以下淘专辑推荐:

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

 楼主| zboi 发表于 2024-3-25 11:46
Jeysir 发表于 2024-3-24 17:51
楼主能否打包成exe, 菜鸟不会python不知道咋用 0.0

已打包成exe,小说下载保存在exe同目录下的小说文件夹内
https://boi.lanzoub.com/b0596fkef
密码:2333

免费评分

参与人数 1热心值 +1 收起 理由
billkeyjian + 1 亲测已失效,谢谢

查看全部评分

baipiao520 发表于 2024-3-24 16:28
zhaoxunzhiyin 发表于 2024-3-24 15:29
RabbitBearLove 发表于 2024-3-24 15:34
感谢楼主分享,学习下
aluda666 发表于 2024-3-24 16:01
顶贴支持楼主
ysjd22 发表于 2024-3-24 16:11
谢谢。。看看有想下的书没有。
 楼主| zboi 发表于 2024-3-24 16:47
baipiao520 发表于 2024-3-24 16:28
感谢分享,就是下载完不知道下到哪去了

就在同目录下的小说文件夹内,我保存在那了,你也可以自己修改保存位置
bdxw0611 发表于 2024-3-24 16:54
学习一下,感谢分享
xk520 发表于 2024-3-24 17:01
感谢分享
shanzhanzhe 发表于 2024-3-24 17:28
学习一下,感谢分享
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

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

GMT+8, 2024-11-24 09:31

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

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