Greasy Fork is available in English.

小说下载器

一个可扩展的通用型小说下载器。

Od 23.05.2021.. Pogledajte najnovija verzija.

Autor
bgme
Ocjene
0 0 0
Verzija
3.6.4.1621776947849
Stvoreno
26.06.2020.
Ažurirano
23.05.2021.
Licenza
AGPL-3.0
Primjenjuje se

小说下载器

一个可扩展的通用型小说下载器。

使用方法

特别提醒:本脚本与Greasemonkey脚本管理器不兼容。本脚本执行下载任务时将播放无声音频,以保证脚本后台运行时不被休眠。

如果本脚本支持该小说网站,当打开小说目录页时,网页右上角会出现下载图标,点击该图标即可开始下载。

如果你要下载的小说章节较多,等待时间可能较长,此时请耐心等待。

你通过右下角进度条了解当前下载进度,或者按下 F12,打开网页控制台查看当前下载状态。

下载完成后,本脚本将会自动下载一个TXT文档及由HTML文件及图片组成的ZIP压缩包。

TXT文档请使用记事本或其它阅读软件进行阅读。

ZIP压缩包,请在解压后,直接双击打开HTML文件(ToC.html 为目录文件)进行阅读。

目前支持小说网站

特别提醒:如欲下载支持列表中网站的付费章节,请登录相应网站帐户,并确定已购买相应付费章节。未登录网站帐户,或未购买的付费章节,下载时将直接忽略,无法进行下载。

站点 公共章节 付费章节 备注
刺猬猫 ✅* *VIP章节仅支持图片版。
SF轻小说 ✅* ✅** *不支持对话小说,例:224282。 **VIP章节仅支持图片版。
起点中文网
起点女生网
晋江文学城 ✅* *VIP章节已使用防盗字体对照表去除空格,如在使用中发现VIP章节仍存在空格,请附上所下载的文件进行反馈。
长佩文学 反爬较严,限制下载速度,每分钟约可下载12章,请耐心等待。
轻之文库轻小说 VIP章节仅支持APP查看
纵横中文网
花语女生网
17K小说网
书海小说网
塔读文学
七猫中文网
废文网 部分小说或章节需登录后查看。
动漫之家 需下载大量图片,速度较慢,请耐心等待。
需占用大量内存,请保证最终生成文件4倍以上内存,即最终下载生成500MB ZIP文件,运行时请保证至少2GB内存空间。可使用筛选函数,分次下载。
UU看书网
亿软网
笔趣窝
书趣阁
顶点小说
星空中文
乐文小说网
266看书
和图书
手打吧
阁笔趣
米趣小说
书书网
八一中文网
御书阁 部分文字被图片替换,请使用HTML版查看。
完本神站
得间小说
轻小说文库
西方奇幻小说网
棉花糖小说网
第一版主网
第二版主网

高阶使用技巧

自定义筛选函数

如欲只下载部分章节,请在点击运行按钮前,按下 F12 打开开发者工具,在 Window 下创建自定义筛选函数 chapterFilter

declare enum Status {
    pending = 0,
    downloading = 1,
    failed = 2,
    finished = 3,
    aborted = 4
}
interface ChapterAdditionalMetadate {
    lastModified?: number;
}
declare class Chapter {
    bookUrl: string;
    bookname: string;
    chapterUrl: string;
    chapterNumber: number;
    chapterName: string | null;
    isVIP: boolean;
    isPaid: boolean | null;
    sectionName: string | null;
    sectionNumber: number | null;
    sectionChapterNumber: number | null;
    chapterParse: ruleClass["chapterParse"];
    charset: string;
    options: object;
    status: Status;
    retryTime: number;
    contentRaw: HTMLElement | null;
    contentText: string | null;
    contentHTML: HTMLElement | null;
    contentImages: attachmentClass[] | null;
    additionalMetadate: ChapterAdditionalMetadate | null;
    constructor(bookUrl: string, bookname: string, chapterUrl: string, chapterNumber: number, chapterName: string | null, isVIP: boolean, isPaid: boolean | null, sectionName: string | null, sectionNumber: number | null, sectionChapterNumber: number | null, chapterParse: ruleClass["chapterParse"], charset: string, options: object);
    init(): Promise<chapterParseObject>;
    private parse;
}

interface chapterFilter {
    (chapter: Chapter): boolean;
}

自定义筛选函数示例:

只下载该本小说前100章内容:

function chapterFilter(chapter) {
  return chapter.chapterNumber <= 100
}

只下载第一卷内容:

function chapterFilter(chapter) {
  return chapter.sectionNumber === 1
}

只下载章节名称中含有“武器”的章节:

function chapterFilter(chapter) {
  return chapter.chapterName.includes("武器")
}

自定义保存参数

自定义保存参数允许您修改保存文件的样式,章节标题等内容。

使用方法大致同自定义筛选函数,即在 Window 下创建如下对象 saveOptions

interface saveOptions {
    mainStyleText?: string;
    tocStyleText?: string;
    getchapterName?: (chapter: Chapter) => string;
}

自定义保存参数示例:

将章节名称格式修改为 第xx章 xxxx

const saveOptions = {
    getchapterName: (chapter) => {
        if (chapter.chapterName) {
            return `第${chapter.chapterNumber.toString()}章 ${chapter.chapterName}`;
        } else {
            return `第${chapter.chapterNumber.toString()}章`;
        }
    }
}
window.saveOptions = saveOptions

更改ZIP文档中章节HTML文件样式:

const saveOptions = {
    "mainStyleText": `p {
  text-indent: 4em;
  display: block;
  line-height: 1.3em;
  margin-top: 0.4em;
  margin-bottom: 0.4em;
}`
}
window.saveOptions = saveOptions

使用用户脚本自动注入自定义保存参数:

如您总是想使用某一自定义保存参数,你可以使用如下用户脚本(根据实际需要修改相应数值),自动向页面注入自定义保存参数。

// ==UserScript==
// @name         auto inject saveOptions
// @namespace    http://tampermonkey.net/
// @version      0.1
// @description  auto inject saveOptions
// @author       You
// @match        *://*/*
// @grant        unsafeWindow
// ==/UserScript==

(function() {
    'use strict';

    const saveOptions = {
        getchapterName: (chapter) => {
            if (chapter.chapterName) {
                return `第${chapter.chapterNumber.toString()}章 ${chapter.chapterName}`;
            } else {
                return `第${chapter.chapterNumber.toString()}章`;
            }
        }
    }
    unsafeWindow.saveOptions = saveOptions
})();

自定义筛选函数同理也可使用用户脚本自动注入。

开发

  1. git clone https://github.com/yingziwu/novel-downloader.git 将项目克隆至本地(访问github可能需要使用代理)。
  2. npm install 安装依赖。
  3. 根据 ruleClass 接口实现相应网站解析规则 Class,并在 rules.ts 中添加相应选择规则。

    interface BookAdditionalMetadate {
        cover?: attachmentClass;
        attachments?: attachmentClass[];
        tags?: string[];
        lastModified?: number;
        serires?: string;
        seriresNumber?: number;
        ids?: string[] | string;
        publisher?: string;
        languages?: string;
    }
    declare class attachmentClass {
        url: string;
        name: string;
        mode: "naive" | "TM";
        headers?: {
            [index: string]: string;
        };
        private defaultHeader;
        status: Status;
        retryTime: number;
        imageBlob: Blob | null;
        constructor(imageUrl: string, name: string, mode: "naive" | "TM");
        init(): Promise<Blob | null>;
        private downloadImage;
        private tmDownloadImage;
    } 
    interface bookParseObject {
        bookUrl: string;
        bookname: string;
        author: string;
        introduction: string | null;
        introductionHTML: HTMLElement | null;
        additionalMetadate: BookAdditionalMetadate;
        chapters: Chapter[];
    }
    interface chapterParseObject {
        chapterName: string | null;
        contentRaw: HTMLElement | null;
        contentText: string | null;
        contentHTML: HTMLElement | null;
        contentImages: attachmentClass[] | null;
        additionalMetadate: ChapterAdditionalMetadate | null;
    }
    interface ruleClass {
        imageMode: "naive" | "TM";
        charset?: string;
        concurrencyLimit?: number;
        maxRunLimit?: number;
        bookParse(chapterParse: ruleClass["chapterParse"]): Promise<bookParseObject>;
        chapterParse(chapterUrl: string, chapterName: string | null, isVIP: boolean, isPaid: boolean | null, charset: string, options: object): Promise<chapterParseObject>;
    }
    
  4. npm run build 编译生成最终脚本文件 dist/bundle.user.js

    License

AGPL-3.0