小编给大家分享一下python中如何使用tkinter打造一个小说下载器,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
站在用户的角度思考问题,与客户深入沟通,找到九台网站设计与九台网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站建设、网站制作、企业官网、英文网站、手机端网站、网站推广、域名注册、网络空间、企业邮箱。业务覆盖九台地区。
先看下效果图
Tkinter 是使用 python 进行窗口视窗设计的模块。Tkinter模块("Tk 接口")是Python的标准Tk GUI工具包的接口。
作为 python 特定的GUI界面,是一个图像的窗口,tkinter是python 自带的,可以编辑的GUI界面,我们可以用GUI 实现很多直观的功能,比如想开发一个计算器,如果只是一个程序输入,输出窗口的话,是没用用户体验的。所有开发一个图像化的小窗口,就是必要的。
代码
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()
然后通过解析网站数据,获取第一个小说的详情页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_encoding sel = get_parsing(response.text) book_name = sel.css('#info h2::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) h2 = selector.css('.bookname h2::text').get() content = selector.css('#content::text').getall() lines = [] for c in content: lines.append(c.strip()) print(h2) text = '\n'.join(lines) file = open(book_name + '.txt', mode='a', encoding='utf-8') file.write(h2) file.write('\n') file.write(text) file.write('\n') file.close()
再来个显示下载内容
def novel_load(title): text.insert(END, '正在保存:{}'.format(title)) # 文本框滚动 text.see(END) # 更新 text.update()
看完了这篇文章,相信你对“python中如何使用tkinter打造一个小说下载器”有了一定的了解,如果想了解更多相关知识,欢迎关注创新互联行业资讯频道,感谢各位的阅读!