Robert Johns | 21 Jan, 2025
Fact checked by Jim Markus

How To Create A Python Unit Converter App with GUI for Beginners

Have you ever needed to quickly convert miles to kilometers or Fahrenheit to Celsius?

In this tutorial, I’ll show you how to create a Python unit conversion tool with a graphical user interface (GUI) using tkinter. By the end, you’ll have a user-friendly application that can handle multiple types of unit conversions, from lengths and weights to temperatures.

This project is beginner-friendly and introduces you to working with Python functions, GUIs, and some basic mathematical operations. Let’s get started!

Why Build a Python Unit Conversion App?

A unit conversion app is a fantastic Python project to enhance your skills. Here’s what you’ll learn:

  • Using tkinter to build a GUI application.
  • Creating reusable functions for different types of conversions.
  • Dynamically updating UI elements based on user input.

Plus, it’s a practical tool you can use in your day-to-day life. Ready? Let’s dive in!

Project Prerequisites

Before we jump into coding, let’s review the skills you’ll need to follow this tutorial.

Don’t worry if you’re not a Python expert just yet! Having a few basics under your belt will make this journey smoother and more enjoyable.

Basic Python Knowledge

You should be familiar with:

  • Variables and functions.
  • Conditional statements and loops.
  • Exception handling (e.g., try-except blocks).

Understanding of tkinter

Some familiarity with tkinter is helpful, but don’t worry — I’ll cover the essentials as we build the app.

A Willingness to Experiment

Building GUIs is a hands-on process. I want you to be prepared to experiment, tweak the code, and debug along the way. It’s all part of the learning process!

Step 1: Set Up Your Project

Before I jump into coding, let’s set up our project:

1. Make sure Python is installed on your computer. If not, download it from the official Python website.
2. Open your favorite code editor or IDE (e.g., VSCode, PyCharm, or even a simple text editor).
3. Create a new Python file, for example, unit_converter.py.

Step 2: Install Required Libraries

This project uses the built-in tkinter library for the GUI. Since tkinter comes pre-installed with Python, you don’t need to install anything extra.

However, make sure you have tkinter installed by running the following command:

python -m tkinter

If the command opens a blank window, you’re good to go!

Step 3: Plan the Conversion Logic

We’ll use a dictionary to map different unit conversion formulas. This keeps the logic organized and makes it easy to add more conversions later. Here’s the initial setup:

conversion_map = {
    "Miles": {"Kilometers": lambda x: x * 1.60934},
    "Kilometers": {"Miles": lambda x: x / 1.60934},
    "Pounds": {"Kilograms": lambda x: x * 0.453592},
    "Kilograms": {"Pounds": lambda x: x / 0.453592},
    "Inches": {"Centimeters": lambda x: x * 2.54},
    "Centimeters": {"Inches": lambda x: x / 2.54},
    "Fahrenheit": {"Celsius": lambda x: (x - 32) * 5/9},
    "Celsius": {"Fahrenheit": lambda x: (x * 9/5) + 32},
}

Each key represents a "from" unit, and its value is another dictionary mapping to "to" units with the corresponding conversion formula as a lambda function.

Step 4: Create the GUI

Import Libraries and Initialize the Main Window

First, import the necessary libraries and set up the main application window:

import tkinter as tk
from tkinter import ttk

# Create the main window
root = tk.Tk()
root.title("Unit Converter")
root.geometry("400x300")
root.configure(bg="#f0f4f7")

Add Input Fields and Dropdowns

We’ll add input fields for the value to be converted and dropdowns for selecting the units:

# Input value
label_value = ttk.Label(root, text="Value:", background="#f0f4f7")
label_value.pack(pady=5)
entry_value = ttk.Entry(root, font=("Helvetica", 12), width=20)
entry_value.pack(pady=5)

# Dropdown for "from" unit
label_from = ttk.Label(root, text="Convert from:", background="#f0f4f7")
label_from.pack(pady=5)
unit_from_var = tk.StringVar()
combo_from = ttk.Combobox(root, textvariable=unit_from_var, font=("Helvetica", 10))
combo_from["values"] = list(conversion_map.keys())
combo_from.pack(pady=5)

# Dropdown for "to" unit
label_to = ttk.Label(root, text="Convert to:", background="#f0f4f7")
label_to.pack(pady=5)
unit_to_var = tk.StringVar()
combo_to = ttk.Combobox(root, textvariable=unit_to_var, font=("Helvetica", 10))
combo_to.pack(pady=5)

Add the Conversion Button and Result Display

Let’s create a button to trigger the conversion and a label to display the result:

# Convert button
button_convert = ttk.Button(root, text="Convert", command=None)
button_convert.pack(pady=10)

# Result label
label_result = ttk.Label(root, text="", font=("Helvetica", 14), background="#f0f4f7", foreground="#333")
label_result.pack(pady=20)

Step 5: Write the Conversion Function

Here’s the function to handle the conversion logic:

def convert():
    unit_from = unit_from_var.get()
    unit_to = unit_to_var.get()
    try:
        value = float(entry_value.get())
    except ValueError:
        label_result.config(text="Invalid input. Please enter a number.")
        return

    if unit_from in conversion_map and unit_to in conversion_map[unit_from]:
        result = conversion_map[unit_from][unit_to](value)
        label_result.config(
            text=f"{value} {unit_from} = {result:.2f} {unit_to}")
    else:
        label_result.config(text="Invalid conversion")

 

Connect the Button to the Function

Update the command parameter of the button to link it to the convert function:

button_convert.config(command=convert)

Step 6: Run the Application

Finally, start the tkinter event loop to launch the application and bask in the glory of what you've created:

root.mainloop()

Full Program Source Code

Here’s the complete code for the Unit Conversion Tool:

'''
Hackr.io Python Tutorial: Unit Converter
'''
import tkinter as tk
from tkinter import ttk

# Conversion functions and data
conversion_map = {
    "Miles": {"Kilometers": lambda x: x * 1.60934},
    "Kilometers": {"Miles": lambda x: x / 1.60934},
    "Pounds": {"Kilograms": lambda x: x * 0.453592},
    "Kilograms": {"Pounds": lambda x: x / 0.453592},
    "Inches": {"Centimeters": lambda x: x * 2.54},
    "Centimeters": {"Inches": lambda x: x / 2.54},
    "Fahrenheit": {"Celsius": lambda x: (x - 32) * 5/9},
    "Celsius": {"Fahrenheit": lambda x: (x * 9/5) + 32},
}


def update_to_units(event):
    """Update the 'to' unit dropdown based on the selected 'from' unit."""
    selected_unit = unit_from_var.get()
    if selected_unit in conversion_map:
        combo_to["values"] = list(conversion_map[selected_unit].keys())
        combo_to.set("")
    else:
        combo_to["values"] = []
        combo_to.set("")


def convert():
    unit_from = unit_from_var.get()
    unit_to = unit_to_var.get()
    try:
        value = float(entry_value.get())
    except ValueError:
        label_result.config(text="Invalid input. Please enter a number.")
        return

    if unit_from in conversion_map and unit_to in conversion_map[unit_from]:
        result = conversion_map[unit_from][unit_to](value)
        label_result.config(
            text=f"{value} {unit_from} = {result:.2f} {unit_to}")
    else:
        label_result.config(text="Invalid conversion")


# Create the main window
root = tk.Tk()
root.title("Unit Converter")
root.geometry("400x300")
root.configure(bg="#f0f4f7")

# Input value
label_value = ttk.Label(root, text="Value:", background="#f0f4f7")
label_value.pack(pady=5)
entry_value = ttk.Entry(root, font=("Arial", 12))
entry_value.pack(pady=5)

# Dropdown for "from" unit
label_from = ttk.Label(root, text="Convert from:", background="#f0f4f7")
label_from.pack(pady=5)
unit_from_var = tk.StringVar()
combo_from = ttk.Combobox(root, textvariable=unit_from_var, font=("Arial", 10))
combo_from["values"] = list(conversion_map.keys())
combo_from.bind("<<ComboboxSelected>>", update_to_units)
combo_from.pack(pady=5)

# Dropdown for "to" unit
label_to = ttk.Label(root, text="Convert to:", background="#f0f4f7")
label_to.pack(pady=5)
unit_to_var = tk.StringVar()
combo_to = ttk.Combobox(root, textvariable=unit_to_var, font=("Arial", 10))
combo_to.pack(pady=5)

# Convert button
button_convert = ttk.Button(
    root, text="Convert", command=convert, style="TButton")
button_convert.pack(pady=10)

# Result label
label_result = ttk.Label(root, text="", font=(
    "Arial", 14), background="#f0f4f7", foreground="#333")
label_result.pack(pady=20)

# Styling
style = ttk.Style()
style.configure("TButton", font=("Arial", 12), padding=5)
style.map("TButton",
          background=[("active", "#0056b3"), ("!active", "#007bff")],
          foreground=[("active", "white"), ("!active", "white")])

# Start the Tkinter event loop
root.mainloop()

Wrapping Up

You’ve just built a Python unit converter app; great work. I hope you enjoyed building this Python project, and you should have an even better understanding of how Python and tkinter  can simplify everyday tasks.

Feel free to expand this project by:

  • Adding more units and conversion types.

  • Including input validation to handle edge cases.

  • Adding advanced features like unit conversion history or saving preferences.

Happy coding!

 

By Robert Johns

Technical Editor for Hackr.io | 15+ Years in Python, Java, SQL, C++, C#, JavaScript, Ruby, PHP, .NET, MATLAB, HTML & CSS, and more... 10+ Years in Networking, Cloud, APIs, Linux | 5+ Years in Data Science | 2x PhDs in Structural & Blast Engineering

View all post by the author

Subscribe to our Newsletter for Articles, News, & Jobs.

I accept the Terms and Conditions.

Disclosure: Hackr.io is supported by its audience. When you purchase through links on our site, we may earn an affiliate commission.

In this article

Learn More

Please login to leave comments