网站首页 > 博客文章 正文
先看看效果
昨天我们已经能够爬任意一本小说,今天我们用一个新的库--tkinter库做一个简单的图形界面,实现类似小说下载器那样的简单功能。
先说一下tkinter库:
Tkinter 是 Python 的标准 GUI 库。Python 使用 Tkinter 可以快速的创建 GUI 应用程序。
Tkinter 组件
Tkinter的提供各种控件,如按钮,标签和文本框,一个GUI应用程序中使用。这些控件通常被称为控件或者部件。
目前有15种Tkinter的部件。我们提出这些部件以及一个简短的介绍,在下面的表:
控件 | 描述 |
Button | 按钮控件;在程序中显示按钮。 |
Canvas | 画布控件;显示图形元素如线条或文本 |
Checkbutton | 多选框控件;用于在程序中提供多项选择框 |
Entry | 输入控件;用于显示简单的文本内容 |
Frame | 框架控件;在屏幕上显示一个矩形区域,多用来作为容器 |
Label | 标签控件;可以显示文本和位图 |
Listbox | 列表框控件;在Listbox窗口小部件是用来显示一个字符串列表给用户 |
Menubutton | 菜单按钮控件,用于显示菜单项。 |
Menu | 菜单控件;显示菜单栏,下拉菜单和弹出菜单 |
Message | 消息控件;用来显示多行文本,与label比较类似 |
Radiobutton | 单选按钮控件;显示一个单选的按钮状态 |
Scale | 范围控件;显示一个数值刻度,为输出限定范围的数字区间 |
Scrollbar | 滚动条控件,当内容超过可视化区域时使用,如列表框。. |
Text | 文本控件;用于显示多行文本 |
Toplevel | 容器控件;用来提供一个单独的对话框,和Frame比较类似 |
Spinbox | 输入控件;与Entry类似,但是可以指定输入范围值 |
PanedWindow | PanedWindow是一个窗口布局管理的插件,可以包含一个或者多个子控件。 |
LabelFrame | labelframe 是一个简单的容器控件。常用与复杂的窗口布局。 |
tkMessageBox | 用于显示你应用程序的消息框。 |
标准属性
标准属性也就是所有控件的共同属性,如大小,字体和颜色等等。
属性 | 描述 |
Dimension | 控件大小; |
Color | 控件颜色; |
Font | 控件字体; |
Anchor | 锚点; |
Relief | 控件样式; |
Bitmap | 位图; |
Cursor | 光标; |
几何管理
Tkinter控件有特定的几何状态管理方法,管理整个控件区域组织,以下是Tkinter公开的几何管理类:包、网格、位置
几何方法 | 描述 |
pack() | 包装; |
grid() | 网格; |
place() | 位置; |
说了一些tkinter库的基础东西,我们就开始制作一个界面,先制作小说下载器的主页面,代码如下:
root = Tk ()
root.title ('小说下载器')
root.geometry ('450x100+250+150')
label = Label (root, text='请输入下载小说名字:', font=('华文行楷'))
label.grid (row=1,column=0)
entry = Entry (root, font=('隶书'))
entry.grid (row=1, column=1)
button1 = Button (root, text='开始下载', font=('隶书', 15)
button1.grid (row=1, column=2)
button2 = Button (root, text='退出程序', font=('隶书', 15))
button2.grid (row=3, columnspan=2)
root.mainloop ()
这样上图那个界面就出来了,出来了还不行,你得实现在界面上能输入小说名称,以及实现下载功能,下载功能就是一个爬虫,上次我们已经实现,这里就不多说了,现在只要在实现输入功能即可。代码如下:
name=entry.get()
这个代码能实现在图形界面上输入并显示
最终实现如图所示:
完整代码如下:
from tkinter import *
import requests,os
from bs4 import BeautifulSoup
import tkinter.messagebox
from tkinter import ttk
title2=[]
url4=[]
# --------下载开始--------
def genxin():
top = Tk ()
top.title ("%s小说下载结果" % entry.get ())
top.geometry ("800x600+600+100")
columns = ("下载章节","下载链接")
treeview = ttk.Treeview (top, show="headings", columns=columns, height='100')
treeview.column ("下载章节", width=250, anchor='center')
treeview.column ("下载链接", width=250, anchor='center')
treeview.heading ("下载章节", text="下载章节")
treeview.heading ("下载链接", text="下载链接")
treeview.pack ()
for write_ in range (min(len (title2),len(url4))): # 写入数据
treeview.insert ('', write_, values=(title2[write_],url4[write_]))
top.mainloop ()
# --------爬虫程序--------
def showinfo():
# 获取输入的内容
#name=input("请输入小说名称:")
name=entry.get()
url='https://www.xbiquwx.la/modules/article/search.php?searchkey={}'.format(name)
html=requests.get(url)
soup=BeautifulSoup(html.content,'lxml')
global booktitle
booktitle = soup.find('td',class_='odd').text
if not os.path.isdir(booktitle): # 判断当前文件夹下是否存在和小说名同名的文件夹
os.makedirs(booktitle) # 若不存在,则创建小说同名文件夹
dd=soup.find_all('tr')
lj=soup.find('td',class_='odd').find('a')['href']
url1='https://www.xbiquwx.la'+ lj
response1 = requests.get(url1)
soup1 = BeautifulSoup(response1.content, 'lxml')
dd = soup1.find_all('dd')
for i in range(len(dd)):
if i < 10:
ttt=dd[i].find ('a')
for title3 in ttt:
title2.append (title3)
title1 = dd[i].find('a').text
url2 = dd[i].find('a')['href']
for url3 in dd[i].find_all('a'):
url4.append(url1+url3['href'])
response2 = requests.get(url1 + url2)
soup2 = BeautifulSoup(response2.content, 'lxml')
xsnr = soup2.find('div', id='content').text.replace(' ','\n')
f = open(booktitle + '/' + title1 + '.txt', 'a+', encoding='utf-8')
f.write(xsnr)
print("正在下载《 {} 》...... {} / {} ".format(title1, i+1, len(dd)))
else:
print('本次共下载 {} 章, 保存地址:{}'.format(i, os.getcwd() + '\\' + booktitle + '\\'))
genxin()
# --------下载器图形界面--------
root = Tk ()
root.title ('小说下载器')
root.geometry ('450x100+250+150')
label = Label (root, text='请输入下载小说名字:', font=('华文行楷'))
label.grid (row=1,column=0)
entry = Entry (root, font=('隶书'))
entry.grid (row=1, column=1)
button1 = Button (root, text='开始下载', font=('隶书', 15),command=showinfo)
button1.grid (row=1, column=2)
button2 = Button (root, text='退出程序', font=('隶书', 15))
button2.grid (row=3, columnspan=2)
root.mainloop ()
猜你喜欢
- 2024-12-18 轻松解析数据!你不可不知的Python宝藏库——parser模块
- 2024-12-18 基于Google Gemini的网页抓取 谷歌怎么抓取网页里的图片
- 2024-12-18 使用Python抓取欧洲足球联赛数据 python 竞彩
- 2024-12-18 网络爬虫——从网站中提取有用的数据
- 2024-12-18 网上售卖几百一月的微信机器,Python几十行代码就能搞定
- 2024-12-18 LangChainV0.2-进阶教程:构建一个RAG应用
- 2024-12-18 Python应用短文,如何自制一个简易的网络爬虫
- 2024-12-18 机器学习第五发:BS教你如何解析网页,规整数据?
- 2024-12-18 python3的bs4模块的安装、介绍 python中bs4模块
- 2024-12-18 Crawl4AI:让AI轻松读懂网页的神器
你 发表评论:
欢迎- 最近发表
-
- 给3D Slicer添加Python第三方插件库
- Python自动化——pytest常用插件详解
- Pycharm下安装MicroPython Tools插件(ESP32开发板)
- IntelliJ IDEA 2025.1.3 发布(idea 2020)
- IDEA+Continue插件+DeepSeek:开发者效率飙升的「三体组合」!
- Cursor:提升Python开发效率的必备IDE及插件安装指南
- 日本旅行时想借厕所、买香烟怎么办?便利商店里能解决大问题!
- 11天!日本史上最长黄金周来了!旅游万金句总结!
- 北川景子&DAIGO缘定1.11 召开记者会宣布结婚
- PIKO‘PPAP’ 洗脑歌登上美国告示牌
- 标签列表
-
- ifneq (61)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)