Python+Tkinter打造签名设计工具


Posted in Python onApril 01, 2022

1.概述

前面我们已经详细的介绍了,怎么使用Tkinter创建属于自己的窗口界面了。整体布局呢我们已经搭建起来,唯一没有实现的一个步骤就是,用户每输入一个名字,就会将个性签名一并显示在这个窗口界面中,今天我就带着大家一起完成这个需求。

今天的文章可以看成是爬虫+Tkinter窗口的结合。昨天我们完成了Tkinter窗口搭建过程,今天需要做的就是利用爬虫得到我们最终想要的个性化签名。网上在线签名网站特别多,我也是任意选取了百度首页排在第一位的那个在线签名网站

2.网页分析

1)网页缺陷

这个文章有一个不好的地方,就是你输入一些空格,网站就给你显示一个空白(如图所示)。

Python+Tkinter打造签名设计工具

我们在写代码的时候,可不能这样,要避免这个问题的发生。我的想法是这样的,如果你输入为空,我就弹窗提醒你。

Python+Tkinter打造签名设计工具

2)页面分析

从图中可以发现,我们在输入框每输入一个名字,进行查询后。相当于给服务器发送了一次post请求,post请求的表单共有四个,从图中可以很清晰地看出来。总的来说,这个网站还是挺简单的,会一些简单的爬虫都可以完成,我这里就不详细介绍了。

Python+Tkinter打造签名设计工具

3)数据的获取

怎么查看网页源代码,相信大家不用我说了吧。我们想要获取的数据,一般的网址是会直接显示在源代码中,比如说今天这个网站,但是对于大多数网站就不一定了。通过定位我们发现,最终想要的个性签名图片,位于class="tu"div标签中,我已经用红色方框标注出来了,由于我们只是获取这一条信息,直接使用正则表达式来获取好了。

Python+Tkinter打造签名设计工具

3.完整代码

通过上述说明,我们已经将准备工作做好了,现在可以书写代码了。这里有几个知识点昨天还没有讲述到,就简单提一下。

entry.get()获取用户输入。我们在输入框输入什么,这里可以捕捉到;

messagebox.showinfo()能够完成弹窗提示,和VBA有点像;

from tkinter import *
from tkinter import messagebox
import requests
import re
from PIL import Image,ImageTk

def func():
    # 获取窗口输入的名字
    name = entry.get()
    print(name)
    # 去掉空格
    name = name.strip()
    # 判断:如果用户输入为空,显示
    if name == "":
        messagebox.showinfo("提示",message="请输入完整的名字")
    else:
        # 请求网站,获取图片
        data = {
            'word': name,
            'sizes': '60',
            'fonts': 'yqk.ttf',
            'fontcolor': ''#000000'
        }
        url = "http://www.uustv.com/"
        result = requests.post(url,data)
        result.encoding = "utf-8"
        html = result.text
        pattern = r'<img src="(.*?)"/></div>'
        img_path = re.findall(pattern,html)[0]
        img_url = url + img_path 
        # 写入到本地
        with open(f'{name}的签名照.gif', "wb") as f:
            f.write(requests.get(img_url).content)
        # 将图片展示在窗口上
        bm = ImageTk.PhotoImage(file=f'{name}的签名照.gif')
        label2 = Label(root,image=bm)
        label2.bm = bm
        label2.grid(row=3,columnspan=2)

# 创建窗口:实例化一个窗口对象。
root = Tk()

# 窗口大小
root.geometry("540x305+374+182")

#  窗口标题
root.title("我的个性签名设计")

# 添加标签控件
label = Label(root,text="签名:",font=("宋体",25),fg="red")
# 定位
label.grid()

# 添加输入框
entry = Entry(root,font=("宋体",25),fg="black")
entry.grid(row=0,column=1)

# 添加点击按钮
button = Button(root,text="签名设计",font=("宋体",25),fg="blue",command=func)
button.grid(row=1,column=1)

# 显示窗口
root.mainloop()

效果如下:

Python+Tkinter打造签名设计工具

4.总结

为了更好的在不懂行的面前装逼,我最终也将程序使用pyinstaller打包了。这样你就可以发给那些文科妹子装装逼,不是很好吗?也会一并提供给大家。

本文有两个遗留问题,可以交给大家解决一下。其一,原网站可以进行签名设计的字体切换,我这个在代码中没有体现出来,你可以自行研究一下。其二,使用pyinstaller打包后的程序,虽然可以运行,但是好慢呀,大家自行下去思考。

以上就是Python+Tkinter打造签名设计工具的详细内容,更多关于Python Tkinter签名设计的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
python sort、sorted高级排序技巧
Nov 21 Python
Python求算数平方根和约数的方法汇总
Mar 09 Python
Python基于pycrypto实现的AES加密和解密算法示例
Apr 10 Python
python3获取当前文件的上一级目录实例
Apr 26 Python
python3调用百度翻译API实现实时翻译
Aug 16 Python
python 执行终端/控制台命令的例子
Jul 12 Python
python创建与遍历List二维列表的方法
Aug 16 Python
pytorch 实现将自己的图片数据处理成可以训练的图片类型
Jan 08 Python
Python短信轰炸的代码
Mar 25 Python
基于python实现获取网页图片过程解析
May 11 Python
详解selenium + chromedriver 被反爬的解决方法
Oct 28 Python
python 实现图片修复(可用于去水印)
Nov 19 Python
Python正则表达式中flags参数的实例详解
Apr 01 #Python
Python+Tkinter制作专属图形化界面
Pyhton爬虫知识之正则表达式详解
python 离散点图画法的实现
Python学习之迭代器详解
Python实战之大鱼吃小鱼游戏的实现
OpenCV实现常见的四种图像几何变换
You might like
PHP MVC框架路由学习笔记
2016/03/02 PHP
PHP程序中的文件锁、互斥锁、读写锁使用技巧解析
2016/03/21 PHP
Yii框架创建cronjob定时任务的方法分析
2017/05/23 PHP
在云虚拟主机部署thinkphp5项目的步骤详解
2017/12/21 PHP
Opacity.js
2007/01/22 Javascript
JavaScript While 循环基础教程
2007/04/05 Javascript
Prototype Class对象学习
2009/07/19 Javascript
js里的prototype使用示例
2010/11/19 Javascript
关于jquery input textare 事件绑定及用法学习
2013/04/03 Javascript
js阻止默认事件与js阻止事件冒泡示例分享 js阻止冒泡事件
2014/01/27 Javascript
jquery幻灯片插件bxslider样式改进实例
2014/10/15 Javascript
JavaScript中window.showModalDialog()用法详解
2014/12/18 Javascript
jQuery中的ready函数与window.onload谁先执行
2016/06/21 Javascript
jQuery事件绑定用法详解
2016/09/08 Javascript
浅谈js中的引用和复制(传值和传址)
2016/09/18 Javascript
浅谈js对象属性 通过点(.) 和方括号([]) 的不同之处
2016/10/29 Javascript
jQuery图片加载显示loading效果
2016/11/04 Javascript
微信小程序 UI与容器组件总结
2017/02/21 Javascript
jQuery使用bind函数实现绑定多个事件的方法
2017/10/11 jQuery
浅谈微信小程序flex布局基础
2018/09/10 Javascript
微信小程序实现的一键连接wifi功能示例
2019/04/24 Javascript
Vue+element 解决浏览器自动填充记住的账号密码问题
2019/06/11 Javascript
微信小程序实现日期格式化和倒计时
2020/11/01 Javascript
详解webpack打包vue项目之后生成的dist文件该怎么启动运行
2019/09/06 Javascript
Python实现模拟时钟代码推荐
2015/11/08 Python
python交互式图形编程实例(一)
2017/11/17 Python
python获取中文字符串长度的方法
2018/11/14 Python
在pandas多重索引multiIndex中选定指定索引的行方法
2018/11/16 Python
python3人脸识别的两种方法
2019/04/25 Python
通过 Python 和 OpenCV 实现目标数量监控
2020/01/05 Python
班班通项目实施方案
2014/02/25 职场文书
人事任命通知书
2015/04/21 职场文书
小鞋子观后感
2015/06/05 职场文书
教师正风肃纪心得体会
2016/01/15 职场文书
2019暑假阅读倡议书
2019/06/24 职场文书
Mysql实现简易版搜索引擎的示例代码
2021/08/30 MySQL