Bird
Raised Fist0
Pythonprogramming~10 mins

Date and time handling in Python - Interactive Code Practice

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Practice - 5 Tasks
Answer the questions below
1fill in blank
easy

Complete the code to import the module needed for date and time handling.

Python
import [1]
Drag options to blanks, or click blank then click option'
Adatetime
Btimeit
Crandom
Dos
Attempts:
3 left
💡 Hint
Common Mistakes
Importing unrelated modules like 'random' or 'os'.
Confusing 'timeit' with 'datetime'.
2fill in blank
medium

Complete the code to get the current date and time.

Python
now = datetime.[1]()
Drag options to blanks, or click blank then click option'
Atime
Bdate
Cdatetime
Dtimedelta
Attempts:
3 left
💡 Hint
Common Mistakes
Using date() which returns only the date.
Using time() which is not a class method here.
3fill in blank
hard

Fix the error in the code to format the current date as 'YYYY-MM-DD'.

Python
formatted_date = now.[1]("%Y-%m-%d")
Drag options to blanks, or click blank then click option'
Aformat
Bstrptime
Cto_string
Dstrftime
Attempts:
3 left
💡 Hint
Common Mistakes
Using strptime() which parses strings to datetime.
Using non-existent methods like to_string().
4fill in blank
hard

Fill both blanks to create a timedelta of 5 days and add it to the current date.

Python
future_date = now + datetime.[1](days=[2])
Drag options to blanks, or click blank then click option'
Atimedelta
B5
C10
Ddate
Attempts:
3 left
💡 Hint
Common Mistakes
Using date instead of timedelta.
Using wrong number of days like 10.
5fill in blank
hard

Fill both blanks to create a dictionary with keys as month names and values as the number of days, only for months with more than 30 days.

Python
months = {"January": 31, "February": 28, "April": 30, "May": 31}
long_months = {k: v for k, v in months.items() if v {BLANK_2}} {{BLANK_2}}
Drag options to blanks, or click blank then click option'
A:
B>
C30
D=
Attempts:
3 left
💡 Hint
Common Mistakes
Using '=' instead of ':' in the dictionary comprehension.
Using '<' or '=' instead of '>' in the condition.

Practice

(1/5)
1. Which Python module is commonly used to work with dates and times?
easy
A. os
B. math
C. random
D. datetime

Solution

  1. Step 1: Recall Python modules for date/time

    The datetime module provides classes for manipulating dates and times.
  2. Step 2: Identify unrelated modules

    math is for math functions, random for random numbers, os for operating system tasks.
  3. Final Answer:

    datetime -> Option D
  4. Quick Check:

    Module for date/time = datetime [OK]
Hint: Remember: datetime handles clocks and calendars [OK]
Common Mistakes:
  • Confusing datetime with math or random modules
  • Using os module for date/time
  • Not importing datetime before use
2. Which of the following is the correct way to create a date object for January 1, 2024 using the datetime module?
easy
A. date = datetime(2024, 1, 1)
B. date = datetime.date('2024-01-01')
C. date = datetime.date(2024, 1, 1)
D. date = datetime.date(1, 1, 2024)

Solution

  1. Step 1: Understand datetime.date constructor

    The date class constructor takes year, month, day as integers in that order.
  2. Step 2: Check each option

    date = datetime.date(2024, 1, 1) uses correct syntax: datetime.date(2024, 1, 1). date = datetime(2024, 1, 1) misses .date. date = datetime.date('2024-01-01') passes a string, which is invalid. date = datetime.date(1, 1, 2024) has wrong argument order.
  3. Final Answer:

    date = datetime.date(2024, 1, 1) -> Option C
  4. Quick Check:

    date(year, month, day) = correct order [OK]
Hint: Use datetime.date(year, month, day) with integers [OK]
Common Mistakes:
  • Passing date as string instead of integers
  • Wrong argument order
  • Missing .date after datetime
3. What will be the output of this code?
from datetime import date, timedelta
start = date(2024, 4, 25)
new_date = start + timedelta(days=10)
print(new_date)
medium
A. 2024-05-05
B. 2024-04-15
C. 2024-04-25
D. Error: unsupported operand

Solution

  1. Step 1: Understand timedelta addition

    Adding timedelta(days=10) to April 25, 2024 adds 10 days.
  2. Step 2: Calculate new date

    April 25 + 10 days = May 5, 2024.
  3. Final Answer:

    2024-05-05 -> Option A
  4. Quick Check:

    25 April + 10 days = 5 May [OK]
Hint: Add timedelta days to date to get new date [OK]
Common Mistakes:
  • Subtracting days instead of adding
  • Confusing timedelta with datetime
  • Expecting string input for timedelta
4. Find the error in this code snippet:
from datetime import datetime
dt = datetime(2024, 2, 30)
print(dt)
medium
A. datetime() requires string arguments
B. February 30 is an invalid date
C. Missing import for timedelta
D. print() cannot display datetime objects

Solution

  1. Step 1: Check date validity

    February 30 does not exist; February has max 29 days in leap years.
  2. Step 2: Understand datetime constructor

    datetime() expects valid year, month, day integers; invalid dates cause ValueError.
  3. Final Answer:

    February 30 is an invalid date -> Option B
  4. Quick Check:

    Invalid date causes error [OK]
Hint: Check if date exists before creating datetime [OK]
Common Mistakes:
  • Assuming all day numbers are valid
  • Missing import errors
  • Thinking print can't show datetime
5. You want to find how many days are between March 1, 2024 and April 15, 2024. Which code correctly calculates this?
hard
A. from datetime import date start = date(2024, 3, 1) end = date(2024, 4, 15) days = (end - start).days print(days)
B. from datetime import datetime start = datetime(2024, 3, 1) end = datetime(2024, 4, 15) days = end + start print(days)
C. from datetime import date days = date(2024, 4, 15) - 45 print(days)
D. from datetime import timedelta start = timedelta(days=2024) end = timedelta(days=101) days = end - start print(days)

Solution

  1. Step 1: Use date objects for subtraction

    Subtracting two date objects gives a timedelta representing the difference.
  2. Step 2: Extract days from timedelta

    Access the .days attribute to get the number of days between dates.
  3. Final Answer:

    45 -> Option A
  4. Quick Check:

    April 15 - March 1 = 45 days [OK]
Hint: Subtract dates, then use .days to get difference [OK]
Common Mistakes:
  • Adding dates instead of subtracting
  • Subtracting integer from date
  • Using timedelta incorrectly as date