前言
今天教大家用户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/
www#gaodaima.com来源gaodai#ma#com搞@@代~&码*网搞代码
先设计一个图像化的界面
代码
<span>from</span> tkinter <span>import</span> *<span> root </span>=<span> Tk() root.title(</span><span>"</span><span>小说下载器</span><span>"</span><span>) root.geometry(</span><span>"</span><span>560x450+400+200</span><span>"</span><span>) label </span>= Label(root, text=<span>"</span><span>请输入下载小说名字:</span><span>"</span>, font=(<span>"</span><span>华文行楷</span><span>"</span>, 20<span>)) label.grid() entry </span>= Entry(root, font=(<span>"</span><span>隶书</span><span>"</span>, 20<span>)) entry.grid(row</span>=0, column=1<span>) text </span>= Listbox(root, font=(<span>"</span><span>隶书</span><span>"</span>, 16), width=50, heigh=15<span>) text.grid(row</span>=2, columnspan=2<span>) button1 </span>= Button(root, text=<span>"</span><span>开始下载</span><span>"</span>, font=(<span>"</span><span>隶书</span><span>"</span>, 15), command=<span>search) button1.grid(row</span>=3, column=<span>0) button2 </span>= Button(root, text=<span>"</span><span>退出程序</span><span>"</span>, font=(<span>"</span><span>隶书</span><span>"</span>, 15), command=<span>root.quit) button2.grid(row</span>=3, column=1<span>) root.mainloop()</span>
效果如下图
开始小说网站的爬虫代码
网页数据是静态网页,但是要搜索,是post请求,需要提交数据参数,如下图所示:
然后通过解析网站数据,获取第一个小说的详情页URL即可。
静态网页的爬取,缺点是不大的。
<span>def</span><span> search(): search_url </span>= <span>"</span><span>http://www.xbiquge.la/modules/article/waps.php</span><span>"</span><span> data </span>=<span> { </span><span>"</span><span>searchkey</span><span>"</span><span>: name } response </span>= requests.post(url=search_url, data=data, headers=<span>headers) selector </span>=<span> get_parsing(response.text) novel_url </span>= selector.css(<span>"</span><span>.even a::attr(href)</span><span>"</span>).extract_first()
获取每本小说的章节网址以及小说名字
1,所有的章节名称以及url地址都包含在dd标签里面。
2,获取url后,需要拼接
<span>"</span><span>/23/23019/11409705.html</span><span>"</span> <span>#</span><span> 这是网页获取到的url</span> <span>"</span><span>http://www.xbiquge.la/23/23019/11409705.html</span><span>"</span> <span>#</span><span> 这是真实的小说章节内容url地址</span>
3,小说名字,直接获取即可。
<span>def</span><span> download_one_book(index_url): response </span>=<span> get_response(index_url) response.encoding </span>=<span> response.apparent_encoding sel </span>=<span> get_parsing(response.text) book_name </span>= sel.css(<span>"</span><span>#info h1::text</span><span>"</span><span>).get() </span><span>#</span><span> 提取了所有章节的下载地址</span> urls = sel.css(<span>"</span><span>#list dd a::attr(href)</span><span>"</span><span>).getall() </span><span>#</span><span> 不要最新的 12 章放在最前main</span> <span>for</span> url <span>in</span><span> urls: chapter_url </span>= <span>"</span><span>http://www.xbiquge.la</span><span>"</span> +<span> url </span><span>print</span>(chapter_url)
保存下载每章小说内容
<span>def</span><span> download_one_chapter(chapter_url, book_name): response </span>=<span> get_response(chapter_url) response.encoding </span>=<span> response.apparent_encoding html </span>=<span> response.text selector </span>=<span> get_parsing(html) h1 </span>= selector.css(<span>"</span><span>.bookname h1::text</span><span>"</span><span>).get() content </span>= selector.css(<span>"</span><span>#content::text</span><span>"</span><span>).getall() lines </span>=<span> [] </span><span>for</span> c <span>in</span><span> content: lines.append(c.strip()) </span><span>print</span><span>(h1) text </span>= <span>"</span><span> </span><span>"</span><span>.join(lines) file </span>= open(book_name + <span>"</span><span>.txt</span><span>"</span>, mode=<span>"</span><span>a</span><span>"</span>, encoding=<span>"</span><span>utf-8</span><span>"</span><span>) file.write(h1) file.write(</span><span>"</span><span> </span><span>"</span><span>) file.write(text) file.write(</span><span>"</span><span> </span><span>"</span><span>) file.close()</span>
再来个显示下载内容
<span>def</span><span> novel_load(title): text.insert(END, </span><span>"</span><span>正在保存:{}</span><span>"</span><span>.format(title)) </span><span>#</span><span> 文本框滚动</span> <span> text.see(END) </span><span>#</span><span> 更新</span> text.update()
最后你还可以把代码给打包成exe文件,分享给你的朋友们用
如果有想要这个程序的小伙伴记得私信我
这个是本篇文章的视频版,详细讲解本次案例步骤,大家可以学习下
https://www.bilibili.com/video/BV13a4y1E7Tb