前言
正文
有多少人,喜欢在寂静无声的夜晚,悄悄掩上房门,倚坐在床头边,抱着手机,借着那微弱的光亮
沉浸在看小说中,时而泣涕涟涟不尽惆怅,时而嘴角上扬喜不自胜
慢慢地,慢慢地愈发沉浸在看小说中······
那么当小说结束,需要新的内容时候,是不是到处找资源下载小说呐~今天小编就带大家自制一款
专属小说下载器给大家!嘻嘻
一、效果展示
二、代码步骤
1)基本开发环境
Python3、Pycharm、parsel、requests、tkinter。
2)目标网页新笔趣阁
3)输入想看的小说内容,点击搜索。
这里会返回很多结果,我只选择第一个。
网页数据是静态网页,但是要搜索,是post请求,需要提交data参数。
4)然后通过解析网站数据,获取第一个小说的详情页url即可。
静态网页的爬取,难度是不大的。
5)获取每本小说的章节url以及小说名字
所有的章节名以及url地址 都包含在 dd 标签里面,获取url后,需要拼接:
'/23/23019/11409705.html' # 这是网页获取到的url
'http://www.xbiquge.la/23/23019/11409705.html' # 这是真实的小说章节内容url地址
小说名字,直接获取即可:
def download_one_book(index_url):
response = get_response(index_url)
response.encoding = response.apparent_encoding
sel = get_parsing(response.text)
book_name = sel.css('#info h1::text').get()
# 提取了所有章节的下载地址
urls = sel.css('#list dd a::attr(href)').getall()
# 不要最新的 12 章放在最前main
for url in urls:
chapter_url = 'http://www.xbiquge.la' + url
print(chapter_url)
保存下载每章小说内容:
def download_one_chapter(chapter_url, book_name):
response = get_response(chapter_url)
response.encoding = response.apparent_encoding
html = response.text
selector = get_parsing(html)
h1 = selector.css('.bookname h1::text').get()
content = selector.css('#content::text').getall()
lines = []
for c in content:
lines.append(c.strip())
print(h1)
text = '\n'.join(lines)
file = open(book_name + '.txt', mode='a', encoding='utf-8')
file.write(h1)
file.write('\n')
file.write(text)
file.write('\n')
file.close()
小说软件界面:
root = Tk()
root.title('小说下载器')
root.geometry('560x450+400+200')
label = Label(root, text='请输入下载小说名字:', font=('华文行楷', 20))
label.grid()
entry = Entry(root, font=('隶书', 20))
entry.grid(row=0, column=1)
text = Listbox(root, font=('隶书', 16), width=50, heigh=15)
text.grid(row=2, columnspan=2)
button1 = Button(root, text='开始下载', font=('隶书', 15), command=search)
button1.grid(row=3, column=0)
button2 = Button(root, text='退出程序', font=('隶书', 15), command=root.quit)
button2.grid(row=3, column=1)
root.mainloop()
总结
哈哈,有了这款下载器,想看什么直接搜索就可以拉~喜欢的记得找我拿源码拉!
关注小编获取更多精彩内容!记得点击传送门哈👇
记得三连哦! 如需打包好的源码+素材免费分享滴!!传送门