Community for developers to learn, share their programming knowledge. Register!
Create First Django Project

Creating a Simple Calculator using Django


The in this article, you can get training on how to create a simple calculator using Django, one of the most popular web frameworks for building robust and scalable web applications. This guide is tailored for intermediate and professional developers who are familiar with Python and web development concepts. By the end of this tutorial, you’ll have a fully functional calculator web application that can perform basic arithmetic operations.

Setting Up Your Django Environment

Before diving into creating our calculator application, we need to ensure that our development environment is set up correctly. Here are the steps to set up Django:

Install Python: Make sure you have Python installed on your machine. You can download it from the official Python website.

Install Django: Use pip to install Django. Open your terminal and run:

pip install django

Create a Virtual Environment (optional but recommended): This helps manage dependencies:

python -m venv myenv
source myenv/bin/activate  # On Windows use `myenv\Scripts\activate`

Install Django in the Virtual Environment:

pip install django

By following these steps, you will have a clean environment ready for your Django project.

Creating the Django Project and Calculator App

Now that your environment is set up, let’s create the Django project and the calculator app.

Create a Django Project:

django-admin startproject mycalculator
cd mycalculator

Create the Calculator App:

python manage.py startapp calculator

Register the App: Open settings.py in your project directory and add 'calculator' to the INSTALLED_APPS list:

INSTALLED_APPS = [
    ...
    'calculator',
]

Defining the Calculator Logic in Views

Next, we will define the logic for our calculator operations in the views.py file of our calculator app. This file will handle the requests and responses for our web application.

Here’s a simple implementation of basic operations such as addition, subtraction, multiplication, and division:

from django.shortcuts import render

def calculator_view(request):
    result = None
    if request.method == 'POST':
        num1 = float(request.POST.get('num1', 0))
        num2 = float(request.POST.get('num2', 0))
        operation = request.POST.get('operation')

        if operation == 'add':
            result = num1 + num2
        elif operation == 'subtract':
            result = num1 - num2
        elif operation == 'multiply':
            result = num1 * num2
        elif operation == 'divide':
            result = num1 / num2 if num2 != 0 else "Error: Division by Zero"

    return render(request, 'calculator/calculator.html', {'result': result})

In this code snippet, we handle the POST request to perform calculations based on the user input.

Building Forms for User Input

To allow users to input numbers and select operations, we need to create a form in our HTML template. Create a new file named calculator.html in the templates/calculator/ directory:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Simple Calculator</title>
</head>
<body>
    <h1>Simple Calculator</h1>
    <form method="POST">
        {% csrf_token %}
        <input type="number" name="num1" placeholder="Enter first number" required>
        <input type="number" name="num2" placeholder="Enter second number" required>
        
        <select name="operation">
            <option value="add">Add</option>
            <option value="subtract">Subtract</option>
            <option value="multiply">Multiply</option>
            <option value="divide">Divide</option>
        </select>
        
        <button type="submit">Calculate</button>
    </form>

    {% if result is not None %}
        <h2>Result: {{ result }}</h2>
    {% endif %}
</body>
</html>

This form will capture user inputs and allow them to select an arithmetic operation.

Implementing URL Routing for Calculator Operations

To map the URL to our calculator view, we need to set up URL routing. Create a file named urls.py in your calculator app directory and add the following code:

from django.urls import path
from .views import calculator_view

urlpatterns = [
    path('', calculator_view, name='calculator'),
]

Next, include this URL configuration in the project's urls.py file:

from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    path('admin/', admin.site.urls),
    path('calculator/', include('calculator.urls')),
]

Designing the User Interface with Templates

In addition to the basic HTML we provided earlier, you may want to add some CSS to enhance the UI. Here’s a simple CSS snippet to improve the appearance:

body {
    font-family: Arial, sans-serif;
    background-color: #f4f4f4;
    padding: 20px;
}

h1 {
    color: #333;
}

form {
    background: #fff;
    padding: 20px;
    border-radius: 5px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}

input, select, button {
    margin: 10px 0;
    padding: 10px;
    width: 100%;
}

button {
    background-color: #007BFF;
    color: white;
    border: none;
    cursor: pointer;
}

Ensure you link this CSS file in your calculator.html file within the <head> tag.

Handling Errors and Validation

It’s crucial to handle potential errors, such as division by zero or invalid inputs. We’ve already included a simple check for dividing by zero in our views. You can further enhance validation by using Django forms, which provide built-in validation mechanisms.

To implement error handling, modify the calculator_view function to include error messages for invalid inputs:

from django.contrib import messages

def calculator_view(request):
    result = None
    if request.method == 'POST':
        try:
            num1 = float(request.POST.get('num1', 0))
            num2 = float(request.POST.get('num2', 0))
            operation = request.POST.get('operation')

            if operation == 'add':
                result = num1 + num2
            elif operation == 'subtract':
                result = num1 - num2
            elif operation == 'multiply':
                result = num1 * num2
            elif operation == 'divide':
                if num2 == 0:
                    messages.error(request, "Error: Division by Zero")
                else:
                    result = num1 / num2

        except ValueError:
            messages.error(request, "Invalid input. Please enter valid numbers.")

    return render(request, 'calculator/calculator.html', {'result': result})

Testing the Calculator Functionality

Testing your application is an essential step to ensure everything works as expected. Use Django's built-in testing framework to create automated tests. Create a file named tests.py in your calculator app directory:

from django.test import TestCase
from .views import calculator_view

class CalculatorTestCase(TestCase):
    def test_addition(self):
        response = self.client.post('/calculator/', {'num1': '10', 'num2': '5', 'operation': 'add'})
        self.assertContains(response, 'Result: 15')

    def test_division_by_zero(self):
        response = self.client.post('/calculator/', {'num1': '10', 'num2': '0', 'operation': 'divide'})
        self.assertContains(response, 'Error: Division by Zero')

Run your tests using:

python manage.py test calculator

Deploying Your Simple Calculator Application

Once you are satisfied with your calculator application, it's time to deploy it. Here are some common deployment options:

Make sure to configure your production settings, including allowed hosts, database settings, and static files.

Summary

In this article, we explored how to create a simple calculator using Django. We set up our environment, created a Django project and app, defined the calculator logic, built user input forms, implemented URL routing, designed a user interface, handled errors, tested functionality, and discussed deployment strategies. This project serves as a solid foundation for anyone looking to expand their Django skills and create more complex web applications.

Last Update: 28 Dec, 2024

Topics:
Django