Home >Backend Development >Python Tutorial >Currency Converter in python
Hi everyone I'll show you today how to create a simple currency converter in Python and Flask to display it on the web.
First we need to make sure that Flask is installed properly, to do that open Powershell or CMD in windows and make sure to run it as administrator by right click it and then run as Administrator, Flask is easy to install by typing this command:
pip install flask
After installing Python ofcourse you can check this link on how to install Python on windows:
(https://www.geeksforgeeks.org/how-to-install-python-on-windows/)
After installing Flask successfully create a folder named currency_converter and inside that folder create a txt file called app.py and make sure to change extension from .txt to .py and then inside currency_converter folder create another folder named (templates) and make sure that this folder named exactly as templates otherwise Flask won't run, then inside templates folder create a single file named index.html you can just create a txt file then rename it index.html and make sure the extension is .html
Here is the code for app.py file:
from flask import Flask, render_template, request, redirect, url_for import requests app = Flask(__name__) API_URL = "https://api.exchangerate-api.com/v4/latest/{}" @app.route("/", methods=["GET", "POST"]) def index(): if request.method == "POST": from_currency = request.form["from_currency"].upper() to_currency = request.form["to_currency"].upper() amount = float(request.form["amount"]) # Fetch exchange rate data response = requests.get(API_URL.format(from_currency)) if response.status_code == 200: data = response.json() rates = data.get("rates", {}) if to_currency in rates: conversion_rate = rates[to_currency] converted_amount = amount * conversion_rate return render_template( "index.html", converted_amount=converted_amount, from_currency=from_currency, to_currency=to_currency, amount=amount, ) else: error = f"Currency '{to_currency}' not found." return render_template("index.html", error=error) else: error = f"Error fetching data for '{from_currency}'." return render_template("index.html", error=error) return render_template("index.html") if __name__ == "__main__": app.run(debug=True)
And here is the code for HTML file with css:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Currency Converter</title> <style> /* General body styling */ body { font-family: 'Arial', sans-serif; margin: 0; padding: 0; background: linear-gradient(135deg, #6dd5fa, #2980b9); color: white; display: flex; justify-content: center; align-items: center; height: 100vh; } /* Centering the container */ .container { background: #ffffff10; /* Semi-transparent white */ border-radius: 10px; padding: 20px 30px; max-width: 400px; width: 100%; box-shadow: 0 8px 16px rgba(0, 0, 0, 0.3); text-align: center; } /* Header styling */ h1 { font-size: 28px; margin-bottom: 20px; color: #fff; text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.8); } /* Input and button styling */ input, button { display: block; width: 100%; margin: 10px 0; padding: 12px; font-size: 16px; border: none; border-radius: 5px; } input { background: #ffffff80; /* Semi-transparent white */ color: #333; } button { background: #2980b9; color: #fff; font-weight: bold; cursor: pointer; transition: background 0.3s ease; } button:hover { background: #1e5786; } /* Result message styling */ .result { background: red; padding: 10px; border-radius: 5px; margin-top: 20px; text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.7); } .result p { margin: 0; font-size: 18px; } /* Error message styling */ .error { color: #ff4d4d; margin: 10px 0; font-weight: bold; } /* Responsive design */ @media (max-width: 480px) { .container { padding: 15px 20px; } h1 { font-size: 22px; } input, button { font-size: 14px; } } </style> </head> <body> <div> <p>Then open Powershell or CMD and navigate to your currency_converter folder location and type:<br> flask run</p> <p>This will create a webserver on your machine with ip and port number as the following:</p> <p>http://127.0.0.1:5000</p><p>Open a web browser then copy this address and paste it in your browser and try the currency converter.</p> <p>For the currency list of codes check this web site:</p> <p>(https://taxsummaries.pwc.com/glossary/currency-codes)</p> <p>Enjoy and thank you so much.</p>
The above is the detailed content of Currency Converter in python. For more information, please follow other related articles on the PHP Chinese website!