Pythonのtkinterライブラリは、GUI機能を開発するライブラリです。
tkinterライブラリ使用することで、デスクトップアプリケーションを作成することができます。
data:image/s3,"s3://crabby-images/9f4ce/9f4ce43e7e605914593bd1620fd1bd741f5eed6a" alt=""
tkinterライブラリの使い方を紹介します
- tkinterライブラリのインストール
- tkinterライブラリの使い方
tkinterライブラリのインストール
tkinterライブラリをインストールする手順を紹介します。
tkinterのインストール
tkinterのインストールします。
コマンドライン
sudo apt install python3-tk
tkinterの動作確認
tkinterの動作を確認して、インストールされているかを確認します。
コマンド実行例
$ python3 -m tkinter
GUI画面
data:image/s3,"s3://crabby-images/876e7/876e7c0327cd96be30cf20a29a10e0f382f2136e" alt=""
data:image/s3,"s3://crabby-images/876e7/876e7c0327cd96be30cf20a29a10e0f382f2136e" alt=""
tkinterライブラリの使い方
tkinterライブラリで、GUI機能を開発する方法を紹介します。
ウインドウ作成
ウィンドウを作成します。
ウインドウを作成
ウインドウを作成します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.mainloop()
コマンド実行例
$ python3 -B tkinter_window.py
GUI画面
data:image/s3,"s3://crabby-images/21516/21516f7ba5d0fbc82bbe70ab1b409e220ed74a90" alt=""
data:image/s3,"s3://crabby-images/21516/21516f7ba5d0fbc82bbe70ab1b409e220ed74a90" alt=""
サイズ指定でウインドウを作成
サイズ指定でウインドウを作成します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
root.mainloop()
コマンド実行例
$ python3 -B tkinter_window_geometry.py
GUI画面
data:image/s3,"s3://crabby-images/c48ee/c48ee590131512fd17677992c77882e31c8e6fbf" alt=""
data:image/s3,"s3://crabby-images/c48ee/c48ee590131512fd17677992c77882e31c8e6fbf" alt=""
タイトル指定でウインドウを作成
タイトル指定でウインドウを作成します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.title("title")
root.mainloop()
コマンド実行例
$ python3 -B tkinter_window_title.py
GUI画面
data:image/s3,"s3://crabby-images/fd7fa/fd7fa27d0b4a24609eaace0ef3a9c7e5693be3fa" alt=""
data:image/s3,"s3://crabby-images/fd7fa/fd7fa27d0b4a24609eaace0ef3a9c7e5693be3fa" alt=""
ラベル
ラベルを追加します。
ラベルを追加
ラベルを追加します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
label = tk.Label(root, text="hogehoge")
label.pack()
root.mainloop()
コマンド実行例
$ python3 -B tkinter_label_pack.py
GUI画面
data:image/s3,"s3://crabby-images/eb8d0/eb8d0d6db55206f76f4fa8218c53a40baec84fa9" alt=""
data:image/s3,"s3://crabby-images/eb8d0/eb8d0d6db55206f76f4fa8218c53a40baec84fa9" alt=""
場所指定でラベルを追加
場所指定でラベルを追加します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
label = tk.Label(root, text="hogehoge")
label.place(x=200, y=200)
root.mainloop()
コマンド実行例
$ python3 -B tkinter_label_place.py
GUI画面
data:image/s3,"s3://crabby-images/8c03d/8c03d56509445bdd789a9c19202916d84006c14a" alt=""
data:image/s3,"s3://crabby-images/8c03d/8c03d56509445bdd789a9c19202916d84006c14a" alt=""
色指定でラベルを追加
色指定でラベルを追加します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
label = tk.Label(root, text="hogehoge", foreground='#ff0000', background='#ffffff')
label.pack()
root.mainloop()
コマンド実行例
$ python3 -B tkinter_label_color.py
GUI画面
data:image/s3,"s3://crabby-images/79d8d/79d8d77d19cfb886a09835d04035f190911103d9" alt=""
data:image/s3,"s3://crabby-images/79d8d/79d8d77d19cfb886a09835d04035f190911103d9" alt=""
テキストボックス
テキストボックスを追加します。
基本的なテキストボックスを追加
基本的なテキストボックスを追加します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
textbox = tk.Entry()
textbox.pack()
root.mainloop()
コマンド実行例
$ python3 -B tkinter_textbox.py
GUI画面
data:image/s3,"s3://crabby-images/c1430/c14300c73842c6618ee3a1b2f323bc3eb98fa2d0" alt=""
data:image/s3,"s3://crabby-images/c1430/c14300c73842c6618ee3a1b2f323bc3eb98fa2d0" alt=""
幅指定でテキストボックスを追加
幅指定でテキストボックスを追加します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
textbox = tk.Entry(width=40)
textbox.pack()
root.mainloop()
コマンド実行例
$ python3 -B tkinter_textbox_width.py
GUI画面
data:image/s3,"s3://crabby-images/2dd86/2dd86f717f0642e6b703c9c8306d17f6d629e63e" alt=""
data:image/s3,"s3://crabby-images/2dd86/2dd86f717f0642e6b703c9c8306d17f6d629e63e" alt=""
テキストボックスを挿入
テキストボックスを挿入します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
textbox = tk.Entry()
textbox.insert(tk.END, "hogehoge")
textbox.pack()
root.mainloop()
コマンド実行例
$ python3 -B tkinter_textbox_insert.py
GUI画面
data:image/s3,"s3://crabby-images/00f6c/00f6cd6af953515ae1c4424d69d9df1e10132145" alt=""
data:image/s3,"s3://crabby-images/00f6c/00f6cd6af953515ae1c4424d69d9df1e10132145" alt=""
テキストボックスの内容を取得
テキストボックスの内容を取得します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
textbox = tk.Entry()
textbox.insert(tk.END, "hogehoge")
textbox.pack()
text = textbox.get()
print(text)
root.mainloop()
コマンド実行例
$ python3 -B tkinter_textbox_get.py
hogehoge
GUI画面
data:image/s3,"s3://crabby-images/af512/af512274f0d019f671118f765c91ea4f0b99f3d6" alt=""
data:image/s3,"s3://crabby-images/af512/af512274f0d019f671118f765c91ea4f0b99f3d6" alt=""
テキストボックスを削除
テキストボックスを削除します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
textbox = tk.Entry()
textbox.insert(tk.END, "hogehoge")
textbox.pack()
textbox.delete(0, tk.END)
root.mainloop()
コマンド実行例
$ python3 -B tkinter_textbox_delete.py
GUI画面
data:image/s3,"s3://crabby-images/39b28/39b286cbbc621e30b312ffb7b5e2b8acb8b73179" alt=""
data:image/s3,"s3://crabby-images/39b28/39b286cbbc621e30b312ffb7b5e2b8acb8b73179" alt=""
ボタン
ボタンを表示します。
ボタンを表示
ボタンを表示します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
button = tk.Button(root, text="hogehoge")
button.pack()
root.mainloop()
コマンド実行例
$ python3 -B tkinter_button.py
GUI画面
data:image/s3,"s3://crabby-images/a62f9/a62f96f0dd2f9a92deb1351beba9243dbf32e916" alt=""
data:image/s3,"s3://crabby-images/a62f9/a62f96f0dd2f9a92deb1351beba9243dbf32e916" alt=""
幅指定でボタンを表示
幅指定でボタンを表示します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
button = tk.Button(root, text="hogehoge", width=40)
button.pack()
root.mainloop()
コマンド実行例
$ python3 -B tkinter_button_width.py
GUI画面
data:image/s3,"s3://crabby-images/6beb5/6beb5759ab9ad0a6d74c0d27eed8a40c1b4091d0" alt=""
data:image/s3,"s3://crabby-images/6beb5/6beb5759ab9ad0a6d74c0d27eed8a40c1b4091d0" alt=""
ボタンのイベントを登録
ボタンのイベントを登録します。
ソースコード
import tkinter as tk
def left_click(event):
print("left click.")
def wheel_click(event):
print("wheel click.")
def right_click(event):
print("right click.")
root = tk.Tk()
root.geometry("400x400")
button = tk.Button(root, text="hogehoge")
button.bind("<Button-1>", left_click)
button.bind("<Button-2>", wheel_click)
button.bind("<Button-3>", right_click)
button.pack()
root.mainloop()
コマンド実行例
$ python3 -B tkinter_button_bind.py
left click.
wheel click.
right click.
GUI画面
data:image/s3,"s3://crabby-images/c8a65/c8a6575ebbfa77e17d8c9fe09903cd8107711afe" alt=""
data:image/s3,"s3://crabby-images/c8a65/c8a6575ebbfa77e17d8c9fe09903cd8107711afe" alt=""
チェックボックス
チェックボックスを追加します。
チェックボックス追加
チェックボックスを追加します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
item_list = ["hogehoge1", "hogehoge2"]
for item in item_list:
checkbox = tk.Checkbutton(root, text=item, selectcolor="#000000")
checkbox.pack()
root.mainloop()
コマンド実行例
$ python3 -B tkinter_checkbox.py
GUI画面
data:image/s3,"s3://crabby-images/e198c/e198cd21fb44a37313a55a3f0276f6a6ea0fb8ea" alt=""
data:image/s3,"s3://crabby-images/e198c/e198cd21fb44a37313a55a3f0276f6a6ea0fb8ea" alt=""
初期状態指定でチェックボックスを追加
初期状態指定でチェックボックスを追加します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
checkbox_value1 = tk.BooleanVar()
checkbox_value1.set(True)
checkbox_value2 = tk.BooleanVar()
checkbox_value2.set(False)
item_dict = {"hogehoge1":checkbox_value1, "hogehoge2":checkbox_value2}
for item, value in item_dict.items():
checkbox = tk.Checkbutton(root, text=item, selectcolor="#000000", variable=value)
checkbox.pack()
root.mainloop()
コマンド実行例
$ python3 -B tkinter_checkbox_init.py
GUI画面
data:image/s3,"s3://crabby-images/4624f/4624f1909d155adaa4a6b42b61839c83645ac9e4" alt=""
data:image/s3,"s3://crabby-images/4624f/4624f1909d155adaa4a6b42b61839c83645ac9e4" alt=""
チェックボックスの状態を取得
チェックボックスの状態を取得します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
checkbox_value1 = tk.BooleanVar()
checkbox_value1.set(True)
checkbox_value2 = tk.BooleanVar()
checkbox_value2.set(False)
item_dict = {"hogehoge1":checkbox_value1, "hogehoge2":checkbox_value2}
for item, value in item_dict.items():
checkbox = tk.Checkbutton(root, text=item, selectcolor="#000000", variable=value)
checkbox.pack()
checkbox_value1_get = checkbox_value1.get()
checkbox_value2_get = checkbox_value2.get()
print(checkbox_value1_get)
print(checkbox_value2_get)
root.mainloop()
コマンド実行例
$ python3 -B tkinter_checkbox_get.py
True
False
GUI画面
data:image/s3,"s3://crabby-images/5f23e/5f23ee61a2daf9516e1d420d0a30bfa072d03e34" alt=""
data:image/s3,"s3://crabby-images/5f23e/5f23ee61a2daf9516e1d420d0a30bfa072d03e34" alt=""
ラジオボタン
ラジオボタンを追加します。
ラジオボタンを追加
ラジオボタンを追加します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
radiobutton_value = tk.IntVar()
item_list = ["hogehoge1", "hogehoge2"]
for index in range(len(item_list)):
radiobutton = tk.Radiobutton(root, text=item_list[index], value=index, variable=radiobutton_value, selectcolor="#000000")
radiobutton.pack()
root.mainloop()
コマンド実行例
$ python3 -B tkinter_radiobutton.py
GUI画面
data:image/s3,"s3://crabby-images/6e6c5/6e6c5d425de8bdb1d6caf97effe3e3716746ba6f" alt=""
data:image/s3,"s3://crabby-images/6e6c5/6e6c5d425de8bdb1d6caf97effe3e3716746ba6f" alt=""
ラジオボタンの状態を取得
ラジオボタンの状態を取得します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
radiobutton_value = tk.IntVar()
item_list = ["hogehoge1", "hogehoge2"]
for index in range(len(item_list)):
radiobutton = tk.Radiobutton(root, text=item_list[index], value=index, variable=radiobutton_value, selectcolor="#000000")
radiobutton.pack()
radiobutton_num = radiobutton_value.get()
print(radiobutton_num)
print(item_list[radiobutton_num])
root.mainloop()
コマンド実行例
$ python3 -B tkinter_radiobutton_get.py
0
hogehoge1
GUI画面
data:image/s3,"s3://crabby-images/e4e60/e4e600f296c46ae76eb5b3ff792975eb50cfe1f5" alt=""
data:image/s3,"s3://crabby-images/e4e60/e4e600f296c46ae76eb5b3ff792975eb50cfe1f5" alt=""
リストボックス
リストボックスを追加します。
リストボックスを追加
リストボックスを追加します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
item_list = ["hogehoge1", "hogehoge2"]
listbox = tk.Listbox(root)
for index in range(len(item_list)):
listbox.insert(index, item_list[index])
listbox.pack()
root.mainloop()
コマンド実行例
$ python3 -B tkinter_listbox.py
GUI画面
data:image/s3,"s3://crabby-images/70c58/70c58b32d6ec551e47c6bad2da101a9bca6b3c4a" alt=""
data:image/s3,"s3://crabby-images/70c58/70c58b32d6ec551e47c6bad2da101a9bca6b3c4a" alt=""
リストボックスの選択イベントを取得
リストボックスの選択イベントを取得する
ソースコード
import tkinter as tk
def select_listbox(event):
select_item = listbox.curselection()
select_num = select_item[0]
print(item_list[select_num])
root = tk.Tk()
root.geometry("400x400")
item_list = ["hogehoge1", "hogehoge2"]
listbox = tk.Listbox(root)
for index in range(len(item_list)):
listbox.insert(index, item_list[index])
listbox.pack()
listbox.bind("<<ListboxSelect>>", select_listbox)
root.mainloop()
コマンド実行例
$ python3 -B tkinter_listbox_curselection.py
hogehoge1
hogehoge2
GUI画面
data:image/s3,"s3://crabby-images/48133/48133303ce11d61b3ae7576a1f76f17192cb1cc2" alt=""
data:image/s3,"s3://crabby-images/48133/48133303ce11d61b3ae7576a1f76f17192cb1cc2" alt=""
スクロールバーありでリストボックスを追加
スクロールバーありでリストボックスを追加する
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
scrollbar = tk.Scrollbar(root)
scrollbar.grid(row=0, column=1, sticky='ns')
item_list = ["hogehoge" + str(num) for num in range(100)]
listbox = tk.Listbox(root, yscrollcommand=scrollbar.set)
for index in range(len(item_list)):
listbox.insert(index, item_list[index])
listbox.grid(row=0, column=0, padx=10, pady=10)
scrollbar.config(command=listbox.yview)
root.mainloop()
コマンド実行例
$ python3 -B tkinter_scrollbar_listbox.py
GUI画面
data:image/s3,"s3://crabby-images/f74ee/f74ee0761c9a5e3c6d5259a33be4e68d60572cff" alt=""
data:image/s3,"s3://crabby-images/f74ee/f74ee0761c9a5e3c6d5259a33be4e68d60572cff" alt=""
キャンバス
キャンバスを追加します。
キャンバスを追加
キャンバスを追加します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
canvas = tk.Canvas(root, width=200, height=200)
canvas.create_rectangle(0, 0, 200, 200, fill="red")
canvas.place(x=100, y=100)
root.mainloop()
コマンド実行例
$ python3 -B tkinter_canvas.py
GUI画面
data:image/s3,"s3://crabby-images/a0615/a06155d64405aaeedc687a8fa5c94da7e914fb1c" alt=""
data:image/s3,"s3://crabby-images/a0615/a06155d64405aaeedc687a8fa5c94da7e914fb1c" alt=""
画像を追加
画像を追加します。
ソースコード
import tkinter as tk
root = tk.Tk()
#root.geometry("400x400")
root.geometry("1000x1000")
image_icon = tk.PhotoImage(file="icon.png")
canvas = tk.Canvas(root, width=1000, height=1000)
canvas.create_image(0, 0, image=image_icon, anchor=tk.NW)
canvas.place(x=50, y=50)
root.mainloop()
コマンド実行例
$ python3 -B tkinter_canvas_image.py
GUI画面
data:image/s3,"s3://crabby-images/b5430/b5430939bc442135a5de07a218a24af90df23f02" alt=""
data:image/s3,"s3://crabby-images/b5430/b5430939bc442135a5de07a218a24af90df23f02" alt=""
メニュー
メニューを追加します。
ソースコード
import tkinter as tk
root = tk.Tk()
root.geometry("400x400")
menubar = tk.Menu(root)
root.config(menu=menubar)
hogehoge_menu = tk.Menu(menubar, tearoff=0)
menubar.add_cascade(label="hogehoge", menu=hogehoge_menu)
hogehoge_menu.add_command(label="hogehoge_item1")
hogehoge_menu.add_command(label="hogehoge_item2")
root.mainloop()
コマンド実行例
$ python3 -B tkinter_menu.py
GUI画面
data:image/s3,"s3://crabby-images/c58ac/c58ac2fb6593b412e3f7a6bf12ef6b2392aef556" alt=""
data:image/s3,"s3://crabby-images/c58ac/c58ac2fb6593b412e3f7a6bf12ef6b2392aef556" alt=""
メッセージボックス
メッセージボックスを表示します。
情報表示
情報表示のメッセージボックスを表示します。
ソースコード
import tkinter.messagebox as messagebox
result = messagebox.showinfo("show info", "message")
print(result)
コマンド実行例
$ python3 -B tkinter_messagebox_showinfo.py
ok
GUI画面
data:image/s3,"s3://crabby-images/96225/96225e82c937fc56bc19af933229d4ca554bc9cc" alt=""
data:image/s3,"s3://crabby-images/96225/96225e82c937fc56bc19af933229d4ca554bc9cc" alt=""
警告表示
警告表示のメッセージボックスを表示します。
ソースコード
import tkinter.messagebox as messagebox
result = messagebox.showwarning("show warning", "message")
print(result)
コマンド実行例
$ python3 -B tkinter_messagebox_showwarning.py
ok
GUI画面
data:image/s3,"s3://crabby-images/21238/21238246bd80dd005c3d0453de19d80d23ddfe89" alt=""
data:image/s3,"s3://crabby-images/21238/21238246bd80dd005c3d0453de19d80d23ddfe89" alt=""
エラー表示
エラー表示のメッセージボックスを表示します。
ソースコード
import tkinter.messagebox as messagebox
result = messagebox.showerror("show error", "message")
print(result)
コマンド実行例
$ python3 -B tkinter_messagebox_showerror.py
ok
GUI画面
data:image/s3,"s3://crabby-images/4793d/4793d9c2bac6c1f6a33ffab5d64336f1b2e20f14" alt=""
data:image/s3,"s3://crabby-images/4793d/4793d9c2bac6c1f6a33ffab5d64336f1b2e20f14" alt=""
Yes/No選択
Yes/No選択のメッセージボックスを表示します。
ソースコード
import tkinter.messagebox as messagebox
result = messagebox.askyesno("ask yes no", "message")
print(result)
コマンド実行例
$ python3 -B tkinter_messagebox_askyesno.py
True
GUI画面
data:image/s3,"s3://crabby-images/9590b/9590bbe668b91a7d52336fcf7886ac2ccb14e37f" alt=""
data:image/s3,"s3://crabby-images/9590b/9590bbe668b91a7d52336fcf7886ac2ccb14e37f" alt=""
質問(Yes/No)
Yes/Noの質問のメッセージボックスを表示します。
ソースコード
import tkinter.messagebox as messagebox
result = messagebox.askquestion("ask question", "message")
print(result)
コマンド実行例
$ python3 -B tkinter_messagebox_askquestion.py
yes
GUI画面
data:image/s3,"s3://crabby-images/ce255/ce255363c4cb14331a9e0e066ad1da944948047f" alt=""
data:image/s3,"s3://crabby-images/ce255/ce255363c4cb14331a9e0e066ad1da944948047f" alt=""
質問(OK/Cancel)
OK/Cancelの質問のメッセージボックスを表示します。
ソースコード
import tkinter.messagebox as messagebox
result = messagebox.askokcancel("ask ok cancel", "message")
print(result)
コマンド実行例
$ python3 -B tkinter_messagebox_askokcancel.py
True
GUI画面
data:image/s3,"s3://crabby-images/c1032/c103207b2235560d1d536bf62cdabc84ce6ef338" alt=""
data:image/s3,"s3://crabby-images/c1032/c103207b2235560d1d536bf62cdabc84ce6ef338" alt=""
リトライ
リトライのメッセージボックスを表示します。
ソースコード
import tkinter.messagebox as messagebox
result = messagebox.askretrycancel("ask retry cancel", "message")
print(result)
コマンド実行例
$ python3 -B tkinter_messagebox_askretrycancel.py
True
GUI画面
data:image/s3,"s3://crabby-images/ce91f/ce91f536fe82789434ce7c96e5af18edadb63cfc" alt=""
data:image/s3,"s3://crabby-images/ce91f/ce91f536fe82789434ce7c96e5af18edadb63cfc" alt=""
まとめ
Pythonライブラリのtkinterの使い方を紹介しました。
- ウインドウを作成できる
- ラベルを追加できる
- テキストボックスを追加できる
- チェックボックスを追加できる
- ボタンを追加できる
- ラジオボタンを追加できる
- リストボックスを追加できる
- キャンバスを追加できる
- メニューを追加できる
- メッセージボックスを追加できる
tkinterライブラリを使った開発では、GUI画面による操作を可能としたアプリケーションを開発することができます。
GUIでは、ユーザーが操作しやすいインターフェースを提供できるので、操作性が向上します。
tkinterライブラリで、GUIアプリケーションを作成できれば、使いやすいアプリケーションが開発できます。