How to get start or end of a day in Python

Lynn Mikami

Lynn Mikami

4 October 2025

How to get start or end of a day in Python

Learning Python can be that quiet space where things actually make sense. Let me walk you through something super practical that you'll use all the time: getting the start and end of a day in Python. Trust me, this comes up way more than you'd think.

When you're building real applications - whether it's a simple script to organize your music files or something bigger - you'll constantly need to work with dates and times. Maybe you want to find all the logs from today, or calculate how long you've been coding (spoiler: probably too long).

The Tools You'll Actually Use

Python has this built-in module called datetime that handles all the time stuff. It's like having a really good Swiss Army knife instead of trying to calculate everything by hand.

from datetime import datetime, date, time

How to Get the Start of Today

Here's the most straightforward way to get midnight at the start of today:

from datetime import datetime, date, time

# Get today's date
today = date.today()
print(f"Today is: {today}")

# Combine it with midnight (00:00:00)
start_of_day = datetime.combine(today, time.min)
print(f"Start of day: {start_of_day}")

When you run this, you'll see something like:

Today is: 2024-01-15
Start of day: 2024-01-15 00:00:00

How to Get the End of Today

For the end of the day, you want 23:59:59.999999 - basically as close to midnight tomorrow as possible without actually being tomorrow:

from datetime import datetime, date, time

today = date.today()
end_of_day = datetime.combine(today, time.max)
print(f"End of day: {end_of_day}")

This gives you:

End of day: 2024-01-15 23:59:59.999999

A More Practical Example That You'll Actually Use

Let's say you're building something to track your coding sessions (because let's be honest, time flies when you're in the zone):

from datetime import datetime, date, time

def get_day_boundaries(target_date=None):
    """
    Get the start and end of a day.
    If no date is provided, uses today.
    """
    if target_date is None:
        target_date = date.today()
    
    start_of_day = datetime.combine(target_date, time.min)
    end_of_day = datetime.combine(target_date, time.max)
    
    return start_of_day, end_of_day

# For today
start, end = get_day_boundaries()
print(f"Today starts at: {start}")
print(f"Today ends at: {end}")

# For a specific date
from datetime import date
specific_date = date(2024, 12, 25)  # Christmas
start, end = get_day_boundaries(specific_date)
print(f"Christmas starts at: {start}")
print(f"Christmas ends at: {end}")

When You're Working With Time Zones

If you're dealing with time zones (which you probably will eventually), you'll want to use the pytz library or the newer zoneinfo module. Here's the modern way:

from datetime import datetime, date, time
from zoneinfo import ZoneInfo

# Get start of day in a specific timezone
today = date.today()
timezone = ZoneInfo("America/Chicago")  # Central Time

start_of_day = datetime.combine(today, time.min, timezone)
end_of_day = datetime.combine(today, time.max, timezone)

print(f"Start of day in Central Time: {start_of_day}")
print(f"End of day in Central Time: {end_of_day}")

Some Real-World Scenarios Where This Matters

Log Analysis: "Show me all the errors from today"

# Filter logs between start and end of day
today_start, today_end = get_day_boundaries()
todays_errors = [log for log in error_logs 
                if today_start <= log.timestamp <= today_end]

Data Processing: "Process all the files created today"

import os
from datetime import datetime

today_start, today_end = get_day_boundaries()

for filename in os.listdir('/path/to/files'):
    file_time = datetime.fromtimestamp(os.path.getctime(filename))
    if today_start <= file_time <= today_end:
        process_file(filename)

Don't Overthink It

Look, I know it might seem like there are a million ways to do this stuff, and honestly, there are. But start with these basics. They'll cover 90% of what you need, and when you run into the edge cases, you'll have a solid foundation to build on.

The important thing is that you're learning and building stuff, even when everything else feels unstable. Code doesn't judge you, it doesn't yell, and if you break something, you can always fix it.

Keep at it, and remember - every expert was once a beginner who felt completely lost. You're doing fine.

Quick Reference for Copy-Pasting

from datetime import datetime, date, time

# Today's boundaries
today = date.today()
start_of_day = datetime.combine(today, time.min)
end_of_day = datetime.combine(today, time.max)

# Print them out
print(f"Day starts: {start_of_day}")
print(f"Day ends: {end_of_day}")

Now go build something cool with it!

💡
Want a great API Testing tool that generates beautiful API Documentation?

Want an integrated, All-in-One platform for your Developer Team to work together with maximum productivity?

Apidog delivers all your demands, and replaces Postman at a much more affordable price!
button

Explore more

The Ultimate Guide for  Lightweight API Client for Mac and Windows

The Ultimate Guide for Lightweight API Client for Mac and Windows

Discover the best lightweight API clients for Mac and Windows. Find a fast, responsive tool that supercharges your API workflow without slowing down your machine.

10 November 2025

How to use Kimi K2 Thinking with Claude Code & Cursor

How to use Kimi K2 Thinking with Claude Code & Cursor

Discover how to integrate Kimi K2 Thinking with Claude Code & Cursor using Moonshot AI’s API. Follow this step-by-step guide to unlock powerful reasoning and coding capabilities in your favorite development tools.

10 November 2025

Claude Code vs Codex vs Cursor vs MiniMax Plan vs GLM Plan: A Comprehensive Comparison for Developers

Claude Code vs Codex vs Cursor vs MiniMax Plan vs GLM Plan: A Comprehensive Comparison for Developers

Explore the ultimate showdown in AI coding assistants: Claude Code vs CodeX vs Cursor vs Minimax Plan vs GLM plan. This technical analysis covers features, pricing, performance, and real-world applications to help developers choose the best tool.

10 November 2025

Practice API Design-first in Apidog

Discover an easier way to build and use APIs