色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

將Python腳本集成到GUI工具包

roborobo_0706 ? 來源:AllTests軟件測試 ? 2023-02-15 16:40 ? 次閱讀

1、前言

測試組合生成器-allpairspy中,作者介紹了allpairspy工具,用于進行測試參數的組合。

隨后發現,如果每次要對新的參數進行組合,都要打開腳本,編寫后再執行,之后還要手動將參數值拷貝到Excel表里,還是有些麻煩,在這里應該要如何進行優化,節約不必要的工作量?

本篇將此腳本進行優化,將集成到Python的GUI工具包(Tkinter),并且可以將結果數據導入到Excel和TXT文件里。

2、簡介

Tkinter(即tkinterface,簡稱“Tk”)本質上是對Tcl/Tk軟件包的Python接口封裝,它是Python官方推薦的GUI工具包,屬于Python自帶的標準庫模塊,當安裝好Python后,就可以直接使用它,而無須另行安裝。

作為一款PythonGUI工具,Tkinter擁有良好的跨平臺性,支持Windows、Linux、Mac平臺,它傳承了Python語法簡潔、代碼易讀的基本特點。

3、快速上手

使用TkinterGUI工具包,快速創建自定義界面。

代碼如下:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# 公眾號:AllTests軟件測試

importtkinter astk

window = tk.Tk()
# 設置窗口title
window.title('公眾號:AllTests軟件測試')
# 設置窗口大小:寬x高
window.geometry('400x200')
# 獲取電腦屏幕大小
print("電腦分辨率 %dx%d "% (window.winfo_screenwidth(), window.winfo_screenheight()))
# 獲取窗口大小,必須先刷新一下屏幕
window.update()
print("窗口分辨率 %dx%d "% (window.winfo_width(), window.winfo_height()))
# 改變背景顏色
window.config(background="#B3B3B3")
# 設置窗口處于頂層
window.attributes('-topmost', True)
# 設置窗口透明度
window.attributes('-alpha', 1)
# 設置窗口被允許最大調整范圍
window.maxsize(600, 600)
# 設置窗口被允許最小調整范圍
window.minsize(50, 50)
# 更改左上角窗口icon圖標
window.iconbitmap('C:/Users/wangmeng/Desktop/mytest/tupian.ico')
# 添加文本內容,并對字體添加相應的格式 font(字體,字號,"字體類型")
tk.Label(window, text="公眾號:AllTests軟件測試", bg="yellow", fg="red", font=('Times', 15, 'bold italic underline')).place(x=80, y=60)
# 添加按鈕,以及按鈕的文本,并通過command參數設置關閉窗口的功能
tk.Button(window, text="關閉", command=window.quit).place(x=200, y=120)
# 進入主循環,顯示主窗口
window.mainloop()
運行腳本,彈出GUI界面。

e87da548-ad0a-11ed-bfe3-dac502259ad0.png

控制臺輸出獲取到的分辨率。

e8971e38-ad0a-11ed-bfe3-dac502259ad0.png

4、測試組合生成器腳本優化

需求點:一個輸入框(將參數組合輸入進去)、一個輸出框(將參數組合分組后打印出來)、分隔符下拉選擇項(用于匹配輸入的參數分隔符)、操作按鈕(運行、導出Excel、導出TXT、刪除、關閉)

代碼如下:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# 公眾號:AllTests軟件測試

fromtkinter importfiledialog
fromtkinter importttk, scrolledtext
fromtkinter importmessagebox
fromtkinter import*
fromallpairspy importAllPairs
importdatetime
importopenpyxl
importos

"""
測試參數組合生成器
"""

# 獲取桌面路徑
defget_path():
returnos.path.join(os.path.expanduser('~'), "Desktop")

# 退出操作
defbutton_quit():
window.quit()

# 刪除操作
defbutton_delete():
scr1.delete('0.0', END)
scr2.delete('0.0', END)

# 運行操作
defbutton_run():
scr2.delete('0.0', END)

globall_key
globaloutput_content
globalexport_content

l_key = []
l_value = []
output_content = []
export_content = []

# 判斷輸入數據是否為空
ifscr1.get('1.0', 'end-1c') != "":
print("輸入數據 "+ "
"+ scr1.get('1.0', 'end-1c'))
# 數據分割
scr_list = scr1.get('0.0', 'end-1c').split("
")
# 判斷是否有空值在列表中,如果有就直接通過remove刪除
while''inscr_list:
scr_list.remove('')
print('列表數據 '+ str(scr_list))
# 共有幾組數據
print(len(scr_list))

iflen(scr_list) != 1:
fori inscr_list:
try:
l = i.split(srclanguage1.get())
# 因素
l_key.append(l[0].strip())
l2 = l[1].split(srclanguage2.get())
# 選擇值
l_value.append(l2)
exceptException asex:
error = str(ex)
messagebox.showerror(title='操作錯誤', message='運行失敗,請檢查輸入數據!'+ "
"+ error)
break

print("數據參數 "+ str(l_value))
print("PAIRWISE:")
fori, pairs inenumerate(AllPairs(l_value)):
# 輸出內容
output_content = "{:2d}: {}".format(i + 1, pairs)
# print(output_content)
scr2.insert(END, output_content)
scr2.insert(END, "
")
# 導出內容
print(pairs)
export_content.append(pairs)
print(export_content)
else:
messagebox.showwarning(title='操作提示', message='輸入數據至少為2組!')
else:
messagebox.showwarning(title='操作提示', message='請輸入正確的數據,再運行!')

# 導出Excel
defbutton_export_excel():
excel_columns = ['A1', 'B1', 'C1', 'D1', 'E1', 'F1', 'G1', 'H1', 'I1', 'J1', 'K1', 'L1', 'M1', 'N1', 'O1',
'P1', 'Q1', 'R1', 'S1', 'T1', 'U1', 'V1', 'W1', 'X1', 'Y1', 'Z1', 'AA1', 'AB1', 'AC1',
'AD1', 'AE1', 'AF1', 'AG1', 'AH1', 'AI1', 'AJ1', 'AK1', 'AL1', 'AM1', 'AN1', 'AO1',
'AP1', 'AQ1', 'AR1', 'AS1', 'AT1', 'AU1', 'AV1', 'AW1', 'AX1', 'AY1', 'AZ1']

# 判斷輸出數據是否為空
ifscr2.get('1.0', 'end-1c') != "":
print("輸出數據 "+ "
"+ scr2.get('1.0', 'end-1c'))

try:
wb = openpyxl.Workbook()
sheet = wb.active
fori, j inzip(l_key, excel_columns):
sheet[j] = i
foritem_tree inexport_content:
value = item_tree
# print(value)
values = [str(strvalue) forstrvalue invalue]
# print(values)
sheet.append(values)

# 將文件直接保存到桌面
# wb.save(f'{get_path()}/case' + datetime.datetime.now().strftime('%Y%m%d%H%M%S') + '.xlsx')
# wb.close()
# messagebox.showinfo(title='導出成功', message='已將Excel文件導出到桌面!')

# 對話框保存文件
filepath = filedialog.asksaveasfilename(initialfile='默認文件名.xlsx', filetypes=[("Excel文件", ".xlsx")])
iffilepath != "":
# print("filepath " + filepath)
wb.save(filepath)
wb.close()
messagebox.showinfo(title='導出成功', message='已導出Excel文件!')
else:
pass
# print("filepath " + filepath)

exceptException asex:
error = str(ex)
messagebox.showerror(title='導出失敗', message='導出失敗!'+ "
"+ error)

else:
messagebox.showwarning(title='操作提示', message='請先運行后,再進行導出!')

# 導出TXT
defbutton_export_txt():
# 判斷輸出數據是否為空
ifscr2.get('1.0', 'end-1c') != "":
print("輸出數據 "+ "
"+ scr2.get('1.0', 'end-1c'))

try:
# 將文件直接保存到桌面
# filepath = f'{get_path()}/case' + datetime.datetime.now().strftime('%Y%m%d%H%M%S') + '.txt'
# info_txt = "到桌面"

# 對話框保存文件
filepath = filedialog.asksaveasfilename(initialfile='默認文件名.txt', filetypes=[("txt文件", ".txt")])
info_txt = ""

# 文件路徑是否為空
iffilepath != "":
# print("filepath " + filepath)
# 寫入文件
withopen(filepath, 'w') asfile_object:
file_object.write(",".join(l_key))
foritem_tree inexport_content:
print(",".join(item_tree))
file_object.write('
'+ ",".join(item_tree))
file_object.close()
messagebox.showinfo(title='導出成功', message='已導出TXT文件'+ info_txt + '!')
else:
pass
# print("filepath " + filepath)

exceptException asex:
error = str(ex)
messagebox.showerror(title='導出失敗', message='導出失敗!'+ "
"+ error)

else:
messagebox.showwarning(title='操作提示', message='請先運行后,再進行導出!')


window = Tk()
# 設置窗口title
window.title("測試參數組合生成器")
# 設置窗口大小:寬x高
window.geometry("850x600")

srclanguage1 = StringVar()
srclanguage1.set('=')
# 標簽
Label(window, text="因素分隔", font=("隸書", 12, 'bold')).place(x=690, y=80)
language1 = ('=', '#')
# 復選框
ttk.Combobox(window, values=language1, width=3, textvariable=srclanguage1, state='readonly').place(x=770, y=80)

srclanguage2 = StringVar()
srclanguage2.set('/')
# 標簽
Label(window, text="內分隔符", font=("隸書", 12, 'bold')).place(x=690, y=110)
language2 = ('/', '+')
# 復選框
ttk.Combobox(window, values=language2, width=3, textvariable=srclanguage2, state='readonly').place(x=770, y=110)

# 標簽
Label(window, text="---輸入數據---", font=("隸書", 14, 'bold italic')).place(x=270, y=1)
# 滾動文本框
scr1 = scrolledtext.ScrolledText(window, width=80, height=15, font=("隸書", 12))
scr1.place(x=15, y=25)

# 標簽
Label(window, text="---輸出結果---", font=("隸書", 14, 'bold italic')).place(x=265, y=270)
# 滾動文本框
scr2 = scrolledtext.ScrolledText(window, width=80, height=15, font=("隸書", 12))
scr2.place(x=15, y=300)

# 按鈕
button1 = Button(window, text="運行", bg="green", font=("隸書", 15), command=button_run)
button1.place(x=560, y=560, width=80, height=30)

# 按鈕
button2 = Button(window, text="導出Excel", bg="yellow", font=("隸書", 15), command=button_export_excel)
button2.place(x=370, y=560, width=100, height=30)

# 按鈕
button3 = Button(window, text="導出TXT", bg="yellow", font=("隸書", 15), command=button_export_txt)
button3.place(x=200, y=560, width=100, height=30)

# 按鈕
button4 = Button(window, text="刪除", bg="red", font=("隸書", 15), command=button_delete)
button4.place(x=40, y=560, width=80, height=30)

# 按鈕
button5 = Button(window, text="關閉", font=("隸書", 15), command=button_quit)
button5.place(x=710, y=560, width=80, height=30)

# 標簽
Label(window, text="輸入數據示例", font=("隸書", 12, 'bold')).place(x=690, y=350)
Label(window, text="因素=A/B/C", font=("隸書", 11)).place(x=690, y=380)
Label(window, text="因素=1/2/3", font=("隸書", 11)).place(x=690, y=410)
Label(window, text="因素=D/E/F", font=("隸書", 11)).place(x=690, y=440)
Label(window, text="公眾號:AllTests軟件測試", font=("微軟雅黑", 10, 'bold'), fg='#EC3832').place(x=680, y=10)

# 顯示窗口
window.mainloop()
運行腳本,彈出GUI界面。

e8a9be62-ad0a-11ed-bfe3-dac502259ad0.png

接下來開始簡單測試一下,先準備一下測試數據:

品牌=X品牌/Y品牌
系統=Windows10/macOS
時間=按天/按周/按月/按年

將測試數據輸入到輸入框中,之后點擊運行,輸出框顯示運行后的結果,總共生成了8條用例。

點擊刪除按鈕,會將輸入和輸出框內的數據都刪除掉。

點擊關閉按鈕,會關閉掉GUI界面。

e8c04dee-ad0a-11ed-bfe3-dac502259ad0.png

代碼里可以設置將文件直接保存到桌面或者彈出對話框自定義保存,這里使用了對話框保存的方式。

點擊導出Excel,文件保存后,會提示導出成功。

e8de0280-ad0a-11ed-bfe3-dac502259ad0.png

打開Excel,顯示的結果數據。

e8f33d62-ad0a-11ed-bfe3-dac502259ad0.png

代碼里可以設置將文件直接保存到桌面或者彈出對話框自定義保存,這里使用了對話框保存的方式。

導出TXT,文件保存后,會提示導出成功。

e90c0b94-ad0a-11ed-bfe3-dac502259ad0.png

打開TXT,顯示的結果數據。

e91d95e4-ad0a-11ed-bfe3-dac502259ad0.png

除了成功的提示信息外,也添加了一些提示與錯誤的信息。

當沒有輸入數據,直接點擊運行按鈕時,會提示:

e930ef0e-ad0a-11ed-bfe3-dac502259ad0.png

當沒有運行,而直接點擊導出Excel或導出TXT時,會提示:

e941c52c-ad0a-11ed-bfe3-dac502259ad0.png

當輸入的參數數據只有一組時,會提示:

e974993e-ad0a-11ed-bfe3-dac502259ad0.png

當輸入的數據格式不對,點擊運行時,會提示:

e9875e70-ad0a-11ed-bfe3-dac502259ad0.png

如上,大概的功能點已經測試完成,可以滿足所要的需求,但是還有一點需要改進,那就是每次打開都要執行腳本,需要改為直接雙擊可運行的文件。

步驟如下:

1、安裝pyinstaller

2、將腳本與圖片放到同一個文件夾目錄

e99813a0-ad0a-11ed-bfe3-dac502259ad0.png

3、執行轉換腳本

pyinstaller -F -i tupian.ico combination_generator.py -w

4、執行完成后,dist目錄里是.exe可執行文件






審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 生成器
    +關注

    關注

    7

    文章

    317

    瀏覽量

    21055
  • GUI
    GUI
    +關注

    關注

    3

    文章

    662

    瀏覽量

    39763
  • python
    +關注

    關注

    56

    文章

    4800

    瀏覽量

    84822

原文標題:將Python腳本集成到GUI工具包-Tkinter

文章出處:【微信號:ExASIC,微信公眾號:ExASIC】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    LabVIEW 2011模塊和工具包(圖像和信號處理)

    `數百種特定應用程序的圖像和信號處理函數集成NI LabVIEW應用程序中。 可將NI LabVIEW擴展至特定的應用,如:聲音和振動測量、機器視覺、RF通信、瞬時與短時信號分析等。 包括NI LabVIEW高級信號處理
    發表于 08-02 15:27

    Python人工智能學習工具包+入門與實踐資料集錦

    ,之后漸漸成為我工作中的第一輔助腳本語言,雖然開發語言是C/C++,但平時的很多文本數據處理任務都交給了Python。這些年來,接觸和使用了很多Python工具包,特別是在文本處理,科
    發表于 11-22 14:46

    如何訪問已與eIQ工具包一起安裝的python版本?

    1.7.3 Ubuntu 安裝程序并將該工具包安裝在遠程板上。 但是,我想知道如何訪問該工具包的命令行工具,以及如何訪問已與eIQ 工具包一起安裝的
    發表于 06-07 06:46

    并口開發調試工具包 (推薦)

    并口開發調試工具包 (推薦):
    發表于 05-27 10:15 ?35次下載
    并口開發調試<b class='flag-5'>工具包</b> (推薦)

    固件工具包

    固件工具包 修改工具包 高興向大家公布這個信息! 首先介紹一下這個工具地用途: 1、修改固件 - 通過此工具能夠修改固件中絕大多數地信息及配置。 2、...
    發表于 03-16 14:49 ?71次下載

    Labview2013各工具包的功能簡介

    Labview2013各工具包的功能簡介Labview2013各工具包的功能簡介
    發表于 11-20 11:20 ?0次下載

    WEBENCH 設計工具包綜合概述

    WEBENCH 設計工具包綜合概述
    發表于 09-15 09:28 ?6次下載
    WEBENCH 設計<b class='flag-5'>工具包</b>綜合概述

    Python基礎-圖像處理工具包

    PythonWare公司提供了免費的圖像處理工具包PIL(Python Image Library),該軟件提供了基本的圖像處理功能,如:改變圖像大小,旋轉圖像,圖像格式轉換,色場空間轉換,圖像
    發表于 03-30 14:09 ?17次下載

    Microchip蘋果配件開發工具包

    這一講是Microchip蘋果配件開發工具包蘋果配件開發工具包
    的頭像 發表于 06-06 13:45 ?2314次閱讀

    Microchip宣布推出全新的GUI開發工具包

    優化后的代碼占用更少的內存,節省物料清單成本。相對于其他依賴高性能內核和3D圖形加速的圖形解決方案,新工具包的高效性能幫助開發人員為Microchip的節能微處理器創建豐富的GUI
    的頭像 發表于 10-22 16:27 ?2524次閱讀

    Cypherbridge uMODBUS工具包

      uMODBUS 工具包專為與各種 SCADA、工業和樓宇控制系統集成而設計。它與標準系統級解決方案兼容,包括:
    的頭像 發表于 06-30 09:23 ?1099次閱讀

    如何把Python腳本集成GUI工具包-Tkinter

    Tkinter(即 tk interface,簡稱“Tk”)本質上是對 Tcl/Tk 軟件Python 接口封裝,它是 Python 官方推薦的 GUI
    的頭像 發表于 05-05 15:02 ?669次閱讀
    如何把<b class='flag-5'>Python</b><b class='flag-5'>腳本集成</b><b class='flag-5'>到</b><b class='flag-5'>GUI</b><b class='flag-5'>工具包</b>-Tkinter

    OneCommand x64的企業應用程序工具包(GUI)

    電子發燒友網站提供《OneCommand x64的企業應用程序工具包(GUI).exe》資料免費下載
    發表于 08-04 09:19 ?0次下載
    OneCommand x64的企業應用程序<b class='flag-5'>工具包</b>(<b class='flag-5'>GUI</b>)

    OneInstall工具包

    電子發燒友網站提供《OneInstall工具包.exe》資料免費下載
    發表于 08-18 14:54 ?0次下載
    OneInstall<b class='flag-5'>工具包</b>

    NPOI WEG報表工具包簡介

    研究使用,發現工具包封裝了部分功能但不完全,使用時還會報一堆不必要的錯誤,所以在這里工具包利用LVOOP進行封裝。
    的頭像 發表于 11-06 10:05 ?1068次閱讀
    NPOI WEG報表<b class='flag-5'>工具包</b>簡介
    主站蜘蛛池模板: 久久AV国产麻豆HD真实| 沙发上小泬12P| 伊人影院亚洲| 狼人无码伊人AV啪啪| 99er4久久视频精品首页| 强奷乱码中文字幕熟女免费| 国产传媒在线观看| 亚洲欧洲日韩国产一区二区三区 | 日韩做A爰片久久毛片A片毛茸茸| 国产AV99激情久久无码天堂| 亚洲色无码播放| 嗯啊…跟校草在教室里做h| 丰满的寡妇hd高清在线观看| 亚洲一卡二卡三卡四卡2021麻豆| 免费人成在线观看网站视频 | 亚洲国产成人精品青青草原100| 旧里番YY6080在线播放| 动漫H片在线播放免费高清| 亚洲乱码中文字幕久久| 欧美熟妇互舔20p| 国产午夜AV无码无片久久96| 2020无码最新国产在线观看| 私人玩物黑丝| 男人的天堂黄色片| 国内精品久久久久久西瓜色吧| 99久久国产宗和精品1上映| 亚洲AV日韩AV欧美在线观看网| 蜜臀AV久久国产午夜福利软件| 年轻的的小婊孑2中文字幕| 动漫美女3d被爆漫画| 在线观看视频中文字幕| 婷婷精品国产亚洲AV在线观看 | 全球真实小U女视频合集| 精品国产自在现线拍400部| 憋尿调教绝望之岛| 在线观看国产区| 亚洲第一国产| 熟女人妻久久精品AV天堂| 男人被绑着强行摸j| 久久国产精品免费网站| 国产乱色伦影片在线观看|