• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

使用tkinter打造一个小说下载器,想看什么小说,就下什么

python 搞java代码 3年前 (2022-05-21) 28次浏览 已收录 0个评论

前言

今天教大家用户Python GUI编程——tkinter 打造一个小说下载器,想看什么小说,就下载什么小说

先看下效果图

 

Tkinter 是使用 python 进行窗口视窗设计的模块。Tkinter模块(“Tk 接口”)是Python的标准Tk GUI工具包的接口。

作为 python 特定的GUI界面,是一个图像的窗口,tkinter是python 自带的,可以编辑的GUI界面,我们可以用GUI 实现很多直观的功能,比如想开发一个计算器,如果只是一个程序输入,输出窗口的话,是没用用户体验的。所有开发一个图像化的小窗口,就是必要的。

 

开发环境

  1. 版 本:anaconda5.2.0(python3.6.5)
  2. 编辑器: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

 


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:使用tkinter打造一个小说下载器,想看什么小说,就下什么

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址