python中如何使用tkinter打造一个小说下载器

发布时间:2021-11-25 15:23:49 作者:小新
来源:亿速云 阅读:305

小编给大家分享一下python中如何使用tkinter打造一个小说下载器,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

先看下效果图

python中如何使用tkinter打造一个小说下载器

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

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

python中如何使用tkinter打造一个小说下载器

先设计一个图像化的界面

代码

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()

python中如何使用tkinter打造一个小说下载器

然后通过解析网站数据,获取第一个小说的详情页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标签里面。

python中如何使用tkinter打造一个小说下载器

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打造一个小说下载器”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

推荐阅读:
  1. Python下载网络小说实例代码
  2. 怎么在python中使用tkinter实现一个计算器

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

python tkinter

上一篇:从PowerShell内存转储中提取执行的脚本内容

下一篇:Lucky双平台勒索者样本的实例分析

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》