Logo

dev-resources.site

for different kinds of informations.

Time finder of any city in the world in Python + Flask

Published at
12/10/2024
Categories
Author
Aj
Categories
1 categories in total
open
Time finder of any city in the world in Python + Flask

Hi everyone, I'm going to show you how to create a simple web app in python that will retrieve time in any city in the world.

First we need to make sure that python is installed you can visit their website for how to install it (https://www.python.org/downloads/windows/)

Then make sure to install Flask to run your app on the web you can install it by opening a command prompt or Powershell in Window and run this command:
pip install flask

And then to ensure that the app can retrieve any city we need to install this library with this command:

pip install geopy timezonefinder pytz

Then create a folder named time for example you can choose any name and inside it create a file named app.py you can do that by right click anywhere in the empty space inside the folder you created and choose text file then name it to app.py with then open it in text editor I use notepad++ you can download it from this link
(https://notepad-plus-plus.org/downloads/)

Here is the code you need to copy it and paste it inside app.py file:

from flask import Flask, request, render_template_string
from datetime import datetime
from geopy.geocoders import Nominatim
from timezonefinder import TimezoneFinder
import pytz

app = Flask(__name__)

# HTML template
html_template = """
<!DOCTYPE html>
<html>
<head>
    <title>City Time Zone</title>
    <style>
        body {
            font-family: Arial, sans-serif;
            background-color: #f4f4f9;
            color: #333;
            margin: 0;
            padding: 0;
            display: flex;
            justify-content: center;
            align-items: center;
            height: 100vh;
        }
        .container {
            text-align: center;
            background: #ffffff;
            padding: 30px;
            border-radius: 10px;
            box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
            width: 400px;
        }
        h1 {
            font-size: 24px;
            margin-bottom: 20px;
        }
        form {
            margin-bottom: 20px;
        }
        input[type="text"] {
            padding: 10px;
            font-size: 16px;
            width: calc(100% - 24px);
            margin-bottom: 10px;
            border: 1px solid #ccc;
            border-radius: 5px;
        }
        button {
            padding: 10px 20px;
            font-size: 16px;
            background-color: #007BFF;
            color: #fff;
            border: none;
            border-radius: 5px;
            cursor: pointer;
        }
        button:hover {
            background-color: #0056b3;
        }
        .error {
            color: red;
            margin-top: 10px;
        }
        .time {
            margin-top: 20px;
            font-size: 18px;
            font-weight: bold;
        }
    </style>
</head>
<body>
    <div class="container">
        <h1>Enter a City to Get the Current Time</h1>
        <form method="post">
            <input type="text" id="city" name="city" placeholder="Enter city name" required>
            <button type="submit">Get Time</button>
        </form>
        {% if error %}
            <p class="error">{{ error }}</p>
        {% endif %}
        {% if time %}
            <p class="time">The current time in {{ city }} is: {{ time }}</p>
        {% endif %}
    </div>
</body>
</html>
"""

@app.route('/', methods=['GET', 'POST'])
def index():
    error = None
    current_time = None
    city = None

    if request.method == 'POST':
        city = request.form.get('city')
        if city:
            city = city.strip()
            try:
                # Geocode the city to get latitude and longitude
                geolocator = Nominatim(user_agent="timezone_app")
                location = geolocator.geocode(city)

                if not location:
                    raise ValueError("City not found. Please check the spelling or try another city.")

                # Find the timezone based on latitude and longitude
                tf = TimezoneFinder()
                timezone_name = tf.timezone_at(lng=location.longitude, lat=location.latitude)

                if not timezone_name:
                    raise ValueError("Could not determine the timezone for this location.")

                # Get the current time in the timezone
                timezone = pytz.timezone(timezone_name)
                current_time = datetime.now(timezone).strftime('%Y-%m-%d %H:%M:%S')
            except Exception as e:
                error = str(e)
        else:
            error = "City name cannot be empty."

    return render_template_string(html_template, error=error, time=current_time, city=city)

if __name__ == '__main__':
    app.run(debug=True)

Now your app is almost ready one final step is to start it by using this command in command prompt or Powershell remember you have to navigate to the exact location of your folder and be inside it when you run this command:

python app.py

Then open up a web browser and type in the address field:
localhost:5000

I hope you like it thank you so much and enjoy.

Featured ones: