Toggle Password Visibility in Entry Widget in Tkinter Python
In Tkinter, the Entry
widget is used to accept user input. When dealing with password fields, you can use the show
attribute to mask the characters. However, to allow users to toggle password visibility, you need to modify the show
attribute dynamically.
In this tutorial, we will explore different ways to toggle password visibility in the Tkinter Entry
widget using the show
attribute.
Examples
1. Basic Toggle Password Visibility
In this example, we create a password entry field and a button that toggles the visibility of the password.
import tkinter as tk
# Create main window
root = tk.Tk()
root.title("Toggle Password Visibility - tutorialkart.com")
root.geometry("400x200")
# Function to toggle password visibility
def toggle_password():
if entry_password.cget("show") == "":
entry_password.config(show="*")
btn_toggle.config(text="Show Password")
else:
entry_password.config(show="")
btn_toggle.config(text="Hide Password")
# Create password entry field
entry_password = tk.Entry(root, width=30, show="*")
entry_password.pack(pady=10)
# Create toggle button
btn_toggle = tk.Button(root, text="Show Password", command=toggle_password)
btn_toggle.pack(pady=10)
# Run main loop
root.mainloop()
Output in Windows:
After entering some password in the Entry widget.
data:image/s3,"s3://crabby-images/0e35c/0e35cd66a14d5eb501829814b806716004fa64fe" alt="Basic Toggle Password Visibility using Button in Tkinter Python"
Click on Show Password button.
data:image/s3,"s3://crabby-images/9e207/9e207f20a12d58ca21ee5d3eb0094a666372251a" alt="Basic Toggle Password Visibility using Button in Tkinter Python - Show Password"
If you click on the Hide Password button, the password shall be hidden.
2. Toggle Password Visibility Using a Checkbox
This example uses a checkbox instead of a button to toggle password visibility.
import tkinter as tk
# Create main window
root = tk.Tk()
root.title("Toggle Password Visibility - tutorialkart.com")
root.geometry("400x200")
# Function to toggle password visibility
def toggle_password():
if var.get():
entry_password.config(show="")
else:
entry_password.config(show="*")
# Create password entry field
entry_password = tk.Entry(root, width=30, show="*")
entry_password.pack(pady=10)
# Create checkbox
var = tk.BooleanVar()
chk_toggle = tk.Checkbutton(root, text="Show Password", variable=var, command=toggle_password)
chk_toggle.pack(pady=10)
# Run main loop
root.mainloop()
Output in Windows:
When you run this program, an Entry field appears with a Checkbox as shown in the following.
data:image/s3,"s3://crabby-images/cab01/cab01edba1cf4029e1c804b084e84159c0fcf844" alt="Basic Toggle Password Visibility using Checkbox in Tkinter Python"
When you enter a password, it is hidden by default.
data:image/s3,"s3://crabby-images/df5a9/df5a9eb923fd5d596471c1f1994095c7714d5d81" alt="Basic Toggle Password Visibility using Checkbox in Tkinter Python - Hide Password"
If you check the Show Password checkbox, then the password is displayed.
data:image/s3,"s3://crabby-images/acf45/acf4587e697fb9d07ae48ba7677649f04c526fe8" alt="Basic Toggle Password Visibility using Checkbox in Tkinter Python - Show Password"
If you uncheck the Show Password checkbox, then the password shall be hidden.
3. Toggle Password Visibility with an Eye Icon
In this example, we use an eye icon button to toggle password visibility.
data:image/s3,"s3://crabby-images/080be/080be09bc9f990fd2b5eec49ee8117334b3eb839" alt=""
data:image/s3,"s3://crabby-images/4f7e9/4f7e91cc045bed9d253a20b33f14890315dcb452" alt=""
import tkinter as tk
from tkinter import PhotoImage
# Create main window
root = tk.Tk()
root.title("Toggle Password Visibility - tutorialkart.com")
root.geometry("400x200")
# Function to toggle password visibility
def toggle_password():
if entry_password.cget("show") == "*":
entry_password.config(show="")
btn_toggle.config(image=eye_closed)
else:
entry_password.config(show="*")
btn_toggle.config(image=eye_open)
# Load eye icon images
eye_open = PhotoImage(file="eye_open.png") # Replace with a valid image path
eye_closed = PhotoImage(file="eye_closed.png") # Replace with a valid image path
# Create password entry field
entry_password = tk.Entry(root, width=30, show="*")
entry_password.pack(pady=10)
# Create toggle button with image
btn_toggle = tk.Button(root, image=eye_open, command=toggle_password)
btn_toggle.pack(pady=10)
# Run main loop
root.mainloop()
Output in Windows:
data:image/s3,"s3://crabby-images/573e8/573e81f2227e2ccb94d4febe09e4f05a56e589fc" alt="Toggle Password Visibility with an Eye Icon in Tkinter Python - Hide Password"
Click on the ‘eye_open’ button.
data:image/s3,"s3://crabby-images/9971e/9971e126d9a50e8a09bd38147b7587a9c71038b4" alt="Toggle Password Visibility with an Eye Icon in Tkinter Python - Show Password"
The password is shown and the button is toggled.
Conclusion
In this tutorial, we explored different ways to toggle password visibility in a Tkinter Entry
widget:
- Using a button to toggle visibility.
- Using a checkbox to control visibility.
- Using an eye icon for a more user-friendly approach.