Prev Next

Python / Core Python Fundamentals Interview Questions

Why should you use Python's logging module instead of print() in production code?

Using print() for diagnostics is fine during quick development, but it has serious limitations in any real-world application: output always goes to stdout, there is no severity level, you cannot turn it off without editing code, and there is no timestamp, file name, or line number.

Python's logging module solves all of these. It provides five severity levels in ascending order: DEBUG, INFO, WARNING, ERROR, CRITICAL. You set a threshold and only messages at or above that level are emitted.

import logging

logging.basicConfig(
    level=logging.DEBUG,
    format='%(asctime)s %(levelname)-8s %(name)s: %(message)s',
    handlers=[
        logging.FileHandler('app.log'),
        logging.StreamHandler()   # also print to console
    ]
)

logger = logging.getLogger(__name__)   # module-level logger

def process_order(order_id):
    logger.debug('Processing order %s', order_id)
    try:
        result = fulfil(order_id)
        logger.info('Order %s fulfilled', order_id)
        return result
    except TimeoutError:
        logger.error('Timeout processing order %s', order_id, exc_info=True)
        raise

Key advantages over print: severity levels let you turn debug output off in production by raising the log level to WARNING. Named loggers (logging.getLogger(__name__)) let library authors log without polluting application output — consumers can configure whether to see library logs. exc_info=True automatically includes the traceback. Handlers route log records to files, external services, or email without touching the application logic.

Which logging level is the lowest (most verbose) in Python's logging module?
Why is logging.getLogger(__name__) recommended over a root logger?

Invest now in Acorns!!! 🚀 Join Acorns and get your $5 bonus!

Invest now in Acorns!!! 🚀
Join Acorns and get your $5 bonus!

Earn passively and while sleeping

Acorns is a micro-investing app that automatically invests your "spare change" from daily purchases into diversified, expert-built portfolios of ETFs. It is designed for beginners, allowing you to start investing with as little as $5. The service automates saving and investing. Disclosure: I may receive a referral bonus.

Invest now!!! Get Free equity stock (US, UK only)!

Use Robinhood app to invest in stocks. It is safe and secure. Use the Referral link to claim your free stock when you sign up!.

The Robinhood app makes it easy to trade stocks, crypto and more.


Webull! Receive free stock by signing up using the link: Webull signup.

More Related questions...

What is Python and what makes it popular for software development? How do variables work in Python, and what does dynamic typing mean? How do conditional statements work in Python? How does the for loop work in Python, and what is the role of range()? When should you use a while loop instead of a for loop in Python? What is a Python list and what operations are most commonly used? What is a tuple in Python and when should you choose it over a list? How do Python dictionaries work and what are the most important operations? What is a Python set and what makes it useful for membership testing? How do you define and call a function in Python? What is variable scope in Python and how does the LEGB rule work? How does exception handling work in Python using try/except? What are the different ways to format strings in Python, and which is preferred? What is list comprehension and how does it differ from a regular for loop? What are *args and **kwargs in Python function definitions? What is a lambda function in Python and when is it appropriate to use one? What is the mutable default argument trap in Python and how do you fix it? How do you use dictionary comprehension to transform data payloads in Python? How does slicing work in Python for lists, strings, and tuples? What is tuple unpacking and extended unpacking in Python? What do the pass, break, and continue statements do in Python loops? What is None in Python, and when should you use 'is' versus '=='? How do you work with nested data structures such as a list of dictionaries? What is a generator in Python and how does it differ from a list? What is a decorator in Python and how do you write one? How do you define a class in Python, and what is the role of __init__? How does inheritance work in Python and what is method resolution order (MRO)? How do you read from and write to files in Python? How do Python modules and imports work? Which Python built-in functions are most important to know for coding interviews? How does Python determine whether a custom object is truthy or falsy? What is the difference between a shallow copy and a deep copy in Python? Which Python string methods are most useful for cleaning and parsing data payloads? How do enumerate() and zip() make loops more Pythonic? What is the Python exception class hierarchy and how do you create custom exceptions? What is the walrus operator (:=) and when is it useful? How does Python's sort work, and what is the difference between sort() and sorted()? What are Python dataclasses and when should you use them instead of regular classes? What is a context manager in Python and how do you implement one? How do Python type hints work and how do you use them in function signatures? Can you create a tuple comprehension in Python, and what is a generator expression? How does recursion work in Python and what are its limitations? How do you parse and build JSON payloads in Python? Why should you use Python's logging module instead of print() in production code? What is PEP 8 and which conventions does it define for Python code?
Show more question and Answers...

Data Science Essentials Interview Questions

Comments & Discussions