python+tkinter搭建GUI可视化测试辅助工具

在测试过程中,比较让人麻烦的就是测试环境数据的维护,比如要测试的接口数据依赖后台的登录凭证token,token又有时效性,每次重新获取都比较麻烦

之前一篇文章,利用接口自动化部署了一套获取token的接口自动化https://blog.csdn.net/HCy996/article/details/118359332

这个只是在pycharm上实现的,怎么把他部署到自己的小页面上呢

像这样:

 

这样就可以在GUI页面上实现了

https://blog.csdn.net/HCy996/article/details/118359332代码基础上 增加代码

加在main函数下

 代码如下

 from tkinter import *
    import tkinter as tk
    import tkinter.messagebox
    from PIL import Image, ImageTk
    # 窗口
    window = tk.Tk()
    window.wm_title('pre环境获取AT')
    window.geometry('450x300')
    # 显示框
    text = Text(window, width=66, height=2)
    text.pack()
    # 画布放置图片
    photo = ImageTk.PhotoImage(Image.open('../Get_accessToken/Data/gif.gif'))
    theLabel = tk.Label(window, justify=tk.LEFT, image=photo, compound=tk.CENTER, font=("华文行楷", 20), fg="white")
    theLabel.pack()
    # 标签 用户名密码
    tk.Label(window, text='用户名:').place(x=100, y=150)
    tk.Label(window, text='密码:').place(x=100, y=190)
    # 用户名输入框
    var_usr_name = tk.StringVar()
    entry_usr_name = tk.Entry(window, textvariable=var_usr_name)
    entry_usr_name.place(x=160, y=150)
    # 密码输入框
    var_usr_pwd = tk.StringVar()
    entry_usr_pwd = tk.Entry(window, textvariable=var_usr_pwd)
    entry_usr_pwd.place(x=160, y=190)
    # 获取at
    def usr_log_in():
        # 输入框获取用户名密码
        usr_name = var_usr_name.get()
        usr_pwd = var_usr_pwd.get()
        # 用户名密码不能为空

        if usr_name == '' or usr_pwd == '':
            tk.messagebox.showerror(message='用户名或密码为空')
        if Get_AccessToken().Login1(usr_name,usr_pwd) == 0:
            # selectableMsg = tk.Text(window, width=35, height=4, relief='flat', bg='gray94',
            #                         wrap='word', font=('consolas', '9'))
            myinfo = Get_AccessToken().Code_token(usr_name, usr_pwd)
            text.insert(1.0,myinfo)
            # selectableMsg.pack(pady=5)
            # w1 = Label(window,text=Get_AccessToken().Code_token(usr_name, usr_pwd))
            # w1.pack()
        else :
            tk.messagebox.showerror(message='用户名或密码错误')
    #退出程序
    def usr_sign_quit():
        window.destroy()
    def usr_clear():
        text.delete('1.0',END)
    # 登录 注册按钮
    bt_login = Button(window, text='获取AT', command=usr_log_in)
    bt_login.place(x=140, y=230)
    bt_logquit = tk.Button(window, text='退出', command=usr_sign_quit)
    bt_logquit.place(x=280, y=230)
    bt_logquit = tk.Button(window, text='清除', command=usr_clear)
    bt_logquit.place(x=220, y=230)
    # 主循环
    window.mainloop()

 最后 ,右击运行即可

注意事项:增加背景图的时候,如果有问题,可以不加背景图

一般增加背景图,会遇到2个问题

一:

PhotoImage函数,只能增加gif的图,如果要加jpg或者png的图片,需要使用ImageTk.PhotoImage

这时候就要引用PIL包from PIL import Image, ImageTk

安装PIL  直接 pip install PIL 是不行的  需要安装pillow

踩过的坑,希望大家可以避免

二:在增加图片的时候的路径,如果文件名不行 就用相对路径包路径,包路径不行,最稳的就是绝对路径

 

注:小弟不是python前端开发,只是一枚小测试,这个工具只是辅助测试,提示测试效率,如有问题,欢迎留言交流

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
这是一个VB6的IDE插件(Addin),使用VB6的IDE直接设计Python的界面。 Python和VB都是能让人快乐的编程语言,我使用了Python之后,很多自己使用的工具都使用Python开发或改写了,因为最终实现的Python代码实在太短了(相比VB),有时候Python一行代码就可以实现VB一个函数的功能。 Python就是这种让人越用越开心的语言。 不过说实在,使用Python开发GUI界面还是麻烦了一些了,自带的标准库Tkinter使用起来非常简单,不过对于习惯了VB拖放控件完成界面设计的偶来说,还是不够人性化。TK也有一个工具叫GUI Builder,不过它使用Layout布局,不够直观,而且用起来很不爽。。 至于PyQt/wxPythonGUI库,尽管有可视化设计工具,但总感觉做一般的轻量级应用是杀鸡用牛刀, 而且不够环保,不够低碳,要带一个很大的库,需要目标机器上夜同样安装了PyQt/wxPython,做不了绿色软件。 所以最终的结果是我更喜欢Tkinter,用起来很简单,绿色环保,真正的跨平台,一个py文件到处运行(担心泄密就编译成pyc)。 很多人都认为TK的界面不够美观,不过我经过多次实验后发现导入Python自带的标准TTK主题库,界面非常Native,不输PyQt/wxPython。 此Addin默认启用TTK支持,也可选择关闭。 总而言之,轻量级GUI,TK+TTK足够。 使用此Addin,你可以不用写一句代码就可以生成一个完整可运行的PythonGUI界面,支持2.X和3.X。 安装方法:将压缩包解压到你希望的目录,然后执行Setup.exe完成注册插件过程,打开VB6就可以用了。 在VB窗体上设计完成界面后(你可以大胆的设置各控件的属性,Addin尽量将其翻译为tkinter的控件属性),点工具栏上的VisualTkinter(图标为一片羽毛),再点'生成代码'按钮,即可生成可运行的Python代码,可以拷贝至剪贴板或保存至文件。 一般情况下你可以不用再改变tkinter的控件属性,但是如果你熟悉tkinter,需要更多的控制,可以一一核对各属性,并且修改,再生成代码。 当然除了用来设计界面外,此ADDIN内置的各控件属性列表可以做为编程参考,比较完整,除了极少数我认为大多数人都不用的属性外,属性定义基本上是我从官方的tkinter文档直接翻译的。 如果还没有VB6,网上找一个VB6精简版即可,不到20M,小巧玲珑。 代码已经在Github上托管,更新的版本可以在这上面找到,需求也可以在上面提: https://github.com/cdhigh/Visual-Tkinter-for-Python
服务端: 服务端程序启动之后弹出窗口,管理员输入IP、端口等信息之后点击启动按钮,服务器启动,服务端窗口自动关闭,之后跳转至服务端信息展示界面,包含用户上线提醒,用户发送信息记录展示。 客户端: 客户端程序启动之后,需要弹出登录界面,当用户成功输入昵称、密码、端口、IP等信息(考虑到用户权限问题,本程序在后台默认有固定IP、端口,)用户只需输入昵称、密码(密码用于后期连接数据库时用来匹配数据库存储的用户信息)。当用户成功输入用户名。昵称、密码等信息客户端登录成功跳转至用户进行端对端的聊天界面。聊天界面大致分为聊天记录展示界面,在线好友信息界面以及用户发送信息处。用户在发送消息处输入想要发送的文本消息,选择在线好友中的好友昵称点击选择好友即可选中您要发给的好友昵称,然后点击发送按钮,即可将消息发送给所选择的好友,同时将信息展示在自己的聊天界面中的聊天记录处 2.2. 功能要求 §2.2.1服务端功能要求: 当管理员输入服务器IP、以及端口等信息之后点击启动按钮之后,服务端正常启动之后,需要保持一直开机状态满足所有用户不论在何时登录之后都能进行与好友之间的聊天交流等,同时服务端还要满足监控用户登录信息,不同用户登录客户端之后,服务器后台能够看到某某客户上线了等提示信息。用于服务端查看好友在线状态同时作为服务器,还要能够监控用户的聊天记录,用于监控用户不能发送一些不利言论,从而将其用户及时作封号处理。阻止其传播一些不健康的言论。 §2.2.2客户端要求: 用户在登录界面输入昵称、密码等信息之后成功登录之后,进行窗口之间的跳转,由登录窗口跳转至进行用户之间的聊天窗口,之前的登录窗口也要随之消失。在聊天窗口之中用户需要根据好友在线信息情况选择自己想要与其进行聊天的对象。用户点击在线好友的昵称点击选择好友即可向该好友发送信息,发送成功之后同时要将其发送的信息以及时间信息展示在自己的窗口之中,同时也要在指定好友的窗口之中有所显示以及时间信息

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

兔子骑乌龟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值