Fatos Morina

Software engineering and personal development

Page 4 of 55

The Pitfalls of Mutating Objects During Iteration in Python


Iteration is a fundamental concept in programming, allowing us to process elements in a collection or iterate over a range of values. However, a common mistake is mutating objects while iterating over them.

Modifying an iterable during iteration can introduce unexpected behavior and yield incorrect results. In this article, we’ll explore the potential pitfalls of mutating objects during iteration and highlight the importance of adopting safer practices to avoid such issues.

Continue reading

How to Avoid Logical Errors: Choose the Right Comparison Operator in Python

An accurate comparison of values is crucial in programming, as it forms the basis of decision-making and logical flow. However, a common mistake when comparing values in Python is using the assignment operator (=) instead of the equality operator (==).

This simple error can have significant consequences, leading to logical errors in your code. In this article, we’ll delve into the importance of choosing the correct comparison operator and highlight how using the wrong operator can result in unintended assignments.

Continue reading

Beware of Variable Scope: A Common Python Mistake

Understanding variable scope is crucial when writing Python code. Failure to grasp the concept can lead to unexpected behavior and hard-to-debug issues. In this article, we’ll explore the second common mistake: misusing variable scope, and provide examples to help you avoid falling into this common pitfall.

Understanding Variable Scope

Variable scope refers to the accessibility and visibility of variables within different parts of your code. In Python, variables can have local or global scope.

Here is a local scope example:

def my_function():
    x = 10
    print(x)

my_function()
print(x)  # NameError: name 'x' is not defined

In this example, the variable x is defined within the my_function() function and has local scope. It is only accessible within the function. Attempting to access x outside the function will result in a NameError.

Here is a global scope example:

x = 10

def my_function():
    print(x)

my_function()
print(x)

Here, x is defined in the global scope. It can be accessed both inside and outside the function, providing consistent output of 10 in both cases.

Common Mistake: Variable Shadowing

Variable shadowing occurs when a local variable has the same name as a variable in a higher scope. This can lead to confusion and unexpected behavior.

x = 10

def my_function():
    x = 20
    print(x)

my_function()
print(x)  # Output: 10

In this example, the local variable x within my_function() shadows the global variable x. When x is printed inside the function, it outputs 20, but outside the function, the global x remains unaffected and outputs 10.

Avoiding the Mistake

To avoid variable scope-related issues:

  • Ensure you understand the concept of variable scope in Python.
  • Use descriptive variable names to minimize the chances of shadowing.
  • Be mindful of modifying global variables within functions; consider using function parameters and return values instead.

Conclusion

Understanding variable scope is essential for writing reliable and bug-free Python code. By recognizing the distinction between local and global variables and avoiding variable shadowing, you can prevent unexpected behavior and maintain code clarity. Remember to take extra care when dealing with variable scope to ensure your code functions as intended.

How to Simplify Error Handling with contextlib.suppress() in Python


Error handling is an essential aspect of writing reliable and robust Python code. Sometimes, however, there are scenarios where you want to intentionally ignore specific exceptions without interrupting the program’s execution flow. In such cases, Python contextlib.suppress() comes to the rescue. In this article, we’ll explore tip number 10: simplifying error handling with contextlib.suppress(), and discover how it allows you to suppress exceptions effectively.

Continue reading

How to Unpack Arbitrary-Length Iterables with the * Operator in Python

In Python, unpacking iterables is a powerful technique that allows you to assign values from an iterable to individual variables. While unpacking a fixed number of elements is straightforward, what if you have an iterable of arbitrary length? Enter the * operator. In this article, we’ll explore tip number 6: unpacking arbitrary-length iterables with the * operator, and discover how it can simplify your code and make it more flexible.

Continue reading

How to Simplify the Management Resources in Python with Context Managers

In Python, managing resources such as files, network connections, or locks is a crucial aspect of writing robust and efficient code.

It’s essential to ensure that resources are properly allocated and released to avoid leaks or unexpected behavior.

Thankfully, Python provides an elegant solution for this problem: context managers.

In this article, we’ll explore how context managers simplify resource management and improve code readability.

Continue reading

How to Quickly Get Sub-Tuples in Python

Python provides a way to get a sub-tuple from an existing tuple by specifying the starting index of the sub-tuple. The syntax for this is similar to that used for lists. We use the slice notation [start_index:] to specify the starting index of the sub-tuple.

Here’s an example:

my_tuple = (1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
print(my_tuple[3:])  # (4, 5, 6, 7, 8, 9, 10)

In this example, we created a tuple called my_tuple that contains ten elements. We then used the slice notation [3:] to get a sub-tuple starting from index 3. The resulting sub-tuple contains all elements from index 3 to the end of the tuple.

We printed the resulting sub-tuple to the console using the print() function. The output of the program is (4, 5, 6, 7, 8, 9, 10).

If we want to get a sub-tuple that contains a specific number of elements, we can use the slice notation [start_index:end_index]. Here’s an example:

my_tuple = (1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
print(my_tuple[3:7])  # (4, 5, 6, 7)

In this example, we used the slice notation [3:7] to get a sub-tuple containing the elements from index 3 to index 6 (inclusive).

That’s basically it.

I hope you find this useful.

How to Quickly Get the Index of an Element in a Tuple in Python

In Python, tuples are an ordered and immutable collection of elements. They are often used to store related pieces of information together, such as the x and y coordinates of a point or the name and age of a person. Sometimes, we may need to find the position of a particular element within a tuple. Python provides a built-in method called index() that makes it easy to accomplish this task. In this article, we will explore how to use the index() method to get the index of an element in a tuple.

The index() method is a built-in method in Python that returns the index of the first occurrence of a specified element in a tuple. The method takes a single argument, which is the element to search for. Here’s an example:

my_tuple = ('a', 1, 'f', 'a', 5, 'a')
print(my_tuple.index('f'))  # 2

In this example, we created a tuple called my_tuple that contains six elements. We then called the index() method on the tuple, passing in the string 'f' as the argument. The method returns the index of the first occurrence of 'f' in the tuple, which is 2. We printed the result to the console using the print() function.

If the specified element is not present in the tuple, the index() method raises a ValueError exception. For example:

my_tuple = ('a', 1, 'f', 'a', 5, 'a')
print(my_tuple.index('z'))  # ValueError: tuple.index(x): x not in tuple

In this example, we called the index() method on the my_tuple tuple, passing in the string 'z' as the argument. Since 'z' is not present in the tuple, the method raises a ValueError exception.

That’s basically it.

I hope you find this useful.

How to Quickly Count the Number of Times an Element Appears in a Tuple in Python

In Python, a tuple is an ordered and immutable collection of elements. Tuples are often used to store related pieces of information together, such as the x and y coordinates of a point, or the name and age of a person. Sometimes, we may need to count the number of times a particular element appears in a tuple. Python provides a built-in method called count() that makes it easy to accomplish this task. In this article, we will explore how to use the count() method to count the number of times an element appears in a tuple.

The count() method is a built-in method in Python that returns the number of times a specified element appears in a tuple. The method takes a single argument, which is the element to be counted. Here’s an example:

my_tuple = ('a', 1, 'f', 'a', 5, 'a')
print(my_tuple.count('a'))  # 3
Continue reading
« Older posts Newer posts »

© 2025 Fatos Morina

Theme by Anders NorenUp ↑