Backend Development
Python Tutorial
ython bugs that every developer is still facing in and how to fix them)
ython bugs that every developer is still facing in and how to fix them)

Written by Rupesh Sharma AKA @hackyrupesh
Python, with its simplicity and beauty, is one of the most popular programming languages in the world. However, even in 2024, certain flaws continue to trouble developers. These problems aren't always due to weaknesses in Python, but rather to its design, behavior, or common misconceptions that result in unanticipated outcomes. In this blog article, we'll look at the top 5 Python issues that every developer still encounters in 2024, as well as their remedies.
1. Mutable Default Arguments: A Silent Trap
The Problem
One of the most infamous Python bugs is the mutable default argument. When a mutable object (like a list or dictionary) is used as a default argument in a function, Python only evaluates this default argument once when the function is defined, not each time the function is called. This leads to unexpected behavior when the function modifies the object.
Example
def append_to_list(value, my_list=[]):
my_list.append(value)
return my_list
print(append_to_list(1)) # Outputs: [1]
print(append_to_list(2)) # Outputs: [1, 2] - Unexpected!
print(append_to_list(3)) # Outputs: [1, 2, 3] - Even more unexpected!
The Solution
To avoid this, use None as the default argument and create a new list inside the function if needed.
def append_to_list(value, my_list=None):
if my_list is None:
my_list = []
my_list.append(value)
return my_list
print(append_to_list(1)) # Outputs: [1]
print(append_to_list(2)) # Outputs: [2]
print(append_to_list(3)) # Outputs: [3]
References
- Python's default argument gotcha
2. The Elusive KeyError in Dictionaries
The Problem
KeyError occurs when trying to access a dictionary key that doesn't exist. This can be especially tricky when working with nested dictionaries or when dealing with data whose structure isn't guaranteed.
Example
data = {'name': 'Alice'}
print(data['age']) # Raises KeyError: 'age'
The Solution
To prevent KeyError, use the get() method, which returns None (or a specified default value) if the key is not found.
print(data.get('age')) # Outputs: None
print(data.get('age', 'Unknown')) # Outputs: Unknown
For nested dictionaries, consider using the defaultdict from the collections module or libraries like dotmap or pydash.
from collections import defaultdict nested_data = defaultdict(lambda: 'Unknown') nested_data['name'] = 'Alice' print(nested_data['age']) # Outputs: Unknown
References
- Python KeyError and how to handle it
3. Silent Errors with try-except Overuse
The Problem
Overusing or misusing try-except blocks can lead to silent errors, where exceptions are caught but not properly handled. This can make bugs difficult to detect and debug.
Example
try:
result = 1 / 0
except:
pass # Silently ignores the error
print("Continuing execution...")
In the above example, the ZeroDivisionError is caught and ignored, but this can mask the underlying issue.
The Solution
Always specify the exception type you are catching, and handle it appropriately. Logging the error can also help in tracking down issues.
try:
result = 1 / 0
except ZeroDivisionError as e:
print(f"Error: {e}")
print("Continuing execution...")
For broader exception handling, you can use logging instead of pass:
import logging
try:
result = 1 / 0
except Exception as e:
logging.error(f"Unexpected error: {e}")
References
- Python's try-except best practices
4. Integer Division: The Trap of Truncation
The Problem
Before Python 3, the division of two integers performed floor division by default, truncating the result to an integer. Although Python 3 resolved this with true division (/), some developers still face issues when unintentionally using floor division (//).
Example
print(5 / 2) # Outputs: 2.5 in Python 3, but would be 2 in Python 2 print(5 // 2) # Outputs: 2
The Solution
Always use / for division unless you specifically need floor division. Be cautious when porting code from Python 2 to Python 3.
print(5 / 2) # Outputs: 2.5 print(5 // 2) # Outputs: 2
For clear and predictable code, consider using decimal.Decimal for more accurate arithmetic operations, especially in financial calculations.
from decimal import Decimal
print(Decimal('5') / Decimal('2')) # Outputs: 2.5
References
- Python Division: / vs //
5. Memory Leaks with Circular References
The Problem
Python's garbage collector handles most memory management, but circular references can cause memory leaks if not handled correctly. When two or more objects reference each other, they may never be garbage collected, leading to increased memory usage.
Example
class Node:
def __init__(self, value):
self.value = value
self.next = None
node1 = Node(1)
node2 = Node(2)
node1.next = node2
node2.next = node1 # Circular reference
del node1
del node2 # Memory not freed due to circular reference
The Solution
To avoid circular references, consider using weak references via the weakref module, which allows references to be garbage collected when no strong references exist.
import weakref
class Node:
def __init__(self, value):
self.value = value
self.next = None
node1 = Node(1)
node2 = Node(2)
node1.next = weakref.ref(node2)
node2.next = weakref.ref(node1) # No circular reference now
Alternatively, you can manually break the cycle by setting references to None before deleting the objects.
node1.next = None node2.next = None del node1 del node2 # Memory is freed
References
- Python Memory Management and Garbage Collection
Conclusion
Even in 2024, Python developers continue to encounter these common bugs. While the language has evolved and improved over the years, these issues are often tied to fundamental aspects of how Python works. By understanding these pitfalls and applying the appropriate solutions, you can write more robust, error-free code. Happy coding!
Written by Rupesh Sharma AKA @hackyrupesh
The above is the detailed content of ython bugs that every developer is still facing in and how to fix them). For more information, please follow other related articles on the PHP Chinese website!
Hot AI Tools
Undress AI Tool
Undress images for free
Undresser.AI Undress
AI-powered app for creating realistic nude photos
AI Clothes Remover
Online AI tool for removing clothes from photos.
Clothoff.io
AI clothes remover
Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!
Hot Article
Hot Tools
Notepad++7.3.1
Easy-to-use and free code editor
SublimeText3 Chinese version
Chinese version, very easy to use
Zend Studio 13.0.1
Powerful PHP integrated development environment
Dreamweaver CS6
Visual web development tools
SublimeText3 Mac version
God-level code editing software (SublimeText3)
SQLAlchemy 2.0 Deprecation Warning and Connection Close Problem Resolving Guide
Aug 05, 2025 pm 07:57 PM
This article aims to help SQLAlchemy beginners resolve the "RemovedIn20Warning" warning encountered when using create_engine and the subsequent "ResourceClosedError" connection closing error. The article will explain the cause of this warning in detail and provide specific steps and code examples to eliminate the warning and fix connection issues to ensure that you can query and operate the database smoothly.
How to automate data entry from Excel to a web form with Python?
Aug 12, 2025 am 02:39 AM
The method of filling Excel data into web forms using Python is: first use pandas to read Excel data, and then use Selenium to control the browser to automatically fill and submit the form; the specific steps include installing pandas, openpyxl and Selenium libraries, downloading the corresponding browser driver, using pandas to read Name, Email, Phone and other fields in the data.xlsx file, launching the browser through Selenium to open the target web page, locate the form elements and fill in the data line by line, using WebDriverWait to process dynamic loading content, add exception processing and delay to ensure stability, and finally submit the form and process all data lines in a loop.
python pandas styling dataframe example
Aug 04, 2025 pm 01:43 PM
Using PandasStyling in JupyterNotebook can achieve the beautiful display of DataFrame. 1. Use highlight_max and highlight_min to highlight the maximum value (green) and minimum value (red) of each column; 2. Add gradient background color (such as Blues or Reds) to the numeric column through background_gradient to visually display the data size; 3. Custom function color_score combined with applymap to set text colors for different fractional intervals (≥90 green, 80~89 orange, 60~79 red,
How to create a virtual environment in Python
Aug 05, 2025 pm 01:05 PM
To create a Python virtual environment, you can use the venv module. The steps are: 1. Enter the project directory to execute the python-mvenvenv environment to create the environment; 2. Use sourceenv/bin/activate to Mac/Linux and env\Scripts\activate to Windows; 3. Use the pipinstall installation package, pipfreeze>requirements.txt to export dependencies; 4. Be careful to avoid submitting the virtual environment to Git, and confirm that it is in the correct environment during installation. Virtual environments can isolate project dependencies to prevent conflicts, especially suitable for multi-project development, and editors such as PyCharm or VSCode are also
How to implement a stack data structure using a list in Python?
Aug 03, 2025 am 06:45 AM
PythonlistScani ImplementationAking append () Penouspop () Popopoperations.1.UseAppend () Two -Belief StotetopoftHestack.2.UseP OP () ToremoveAndreturnthetop element, EnsuringTocheckiftHestackisnotemptoavoidindexError.3.Pekattehatopelementwithstack [-1] on
python schedule library example
Aug 04, 2025 am 10:33 AM
Use the Pythonschedule library to easily implement timing tasks. First, install the library through pipinstallschedule, then import the schedule and time modules, define the functions that need to be executed regularly, then use schedule.every() to set the time interval and bind the task function. Finally, call schedule.run_pending() and time.sleep(1) in a while loop to continuously run the task; for example, if you execute a task every 10 seconds, you can write it as schedule.every(10).seconds.do(job), which supports scheduling by minutes, hours, days, weeks, etc., and you can also specify specific tasks.
How to handle large datasets in Python that don't fit into memory?
Aug 14, 2025 pm 01:00 PM
When processing large data sets that exceed memory in Python, they cannot be loaded into RAM at one time. Instead, strategies such as chunking processing, disk storage or streaming should be adopted; CSV files can be read in chunks through Pandas' chunksize parameters and processed block by block. Dask can be used to realize parallelization and task scheduling similar to Pandas syntax to support large memory data operations. Write generator functions to read text files line by line to reduce memory usage. Use Parquet columnar storage format combined with PyArrow to efficiently read specific columns or row groups. Use NumPy's memmap to memory map large numerical arrays to access data fragments on demand, or store data in lightweight data such as SQLite or DuckDB.
python logging to file example
Aug 04, 2025 pm 01:37 PM
Python's logging module can write logs to files through FileHandler. First, call the basicConfig configuration file processor and format, such as setting the level to INFO, using FileHandler to write app.log; secondly, add StreamHandler to achieve output to the console at the same time; Advanced scenarios can use TimedRotatingFileHandler to divide logs by time, for example, setting when='midnight' to generate new files every day and keep 7 days of backup, and make sure that the log directory exists; it is recommended to use getLogger(__name__) to create named loggers, and produce


