使用tkinter打造一个小说下载器,想看什么小说,就下什么[Python基础]
前言
今天教大家用户Python GUI编程——tkinter 打造一个小说下载器,想看什么小说,就下载什么小说
先看下效果图
Tkinter 是使用 python 进行窗口视窗设计的模块。Tkinter模块("Tk 接口")是Python的标准Tk GUI工具包的接口。
作为 python 特定的GUI界面,是一个图像的窗口,tkinter是python 自带的,可以编辑的GUI界面,我们可以用GUI 实现很多直观的功能,比如想开发一个计算器,如果只是一个程序输入,输出窗口的话,是没用用户体验的。所有开发一个图像化的小窗口,就是必要的。
开发环境
- 版 本:anaconda5.2.0(python3.6.5)
- 编辑器:pycharm
本次目标
爬取笔趣阁小说,使用 tkinter 打造一个小说下载器
http://www.xbiquge.la/
先设计一个图像化的界面
代码
from tkinter import *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()
效果如下图
开始小说网站的爬虫代码
网页数据是静态网页,但是要搜索,是post请求,需要提交数据参数,如下图所示:
然后通过解析网站数据,获取第一个小说的详情页URL即可。
静态网页的爬取,缺点是不大的。
def search():search_url
= "http://www.xbiquge.la/modules/article/waps.php"data
= {"searchkey": name}
response
= requests.post(url=search_url, data=data, headers=headers)selector
= get_parsing(response.text)novel_url
= selector.css(".even a::attr(href)").extract_first()
获取每本小说的章节网址以及小说名字
1,所有的章节名称以及url地址都包含在dd标签里面。
2,获取url后,需要拼接
"/23/23019/11409705.html"# 这是网页获取到的url"http://www.xbiquge.la/23/23019/11409705.html"# 这是真实的小说章节内容url地址
3,小说名字,直接获取即可。
def download_one_book(index_url):response
= get_response(index_url)response.encoding
= response.apparent_encodingsel
= 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_encodinghtml
= response.textselector
= 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
= "".join(lines)file
= open(book_name + ".txt", mode="a", encoding="utf-8")file.write(h1)
file.write(
"")file.write(text)
file.write(
"")file.close()
再来个显示下载内容
def novel_load(title):text.insert(END,
"正在保存:{}".format(title))# 文本框滚动text.see(END)
# 更新
text.update()
最后你还可以把代码给打包成exe文件,分享给你的朋友们用
如果有想要这个程序的小伙伴记得私信我
这个是本篇文章的视频版,详细讲解本次案例步骤,大家可以学习下
https://www.bilibili.com/video/BV13a4y1E7Tb
以上是 使用tkinter打造一个小说下载器,想看什么小说,就下什么[Python基础] 的全部内容, 来源链接: utcz.com/z/530205.html