In the last two years, I've used Python extensively as my main programming language. Dive into these tricky Python questions, inspired by real-world issues and online challenges, to test and enhance your coding skills.
So are you ready to get your mind blow away (from Python question)?
Questions
Notice 1!: To each question, there is an answer with an explanation (link below each item).
Notice 2!: For each question think what will be the output.
Question 1
exapmle_dict = dict()
exapmle_dict.a = "string"
print(exapmle_dict)
Go to answer 1
Question 2
class Json:
def __init__(self, *args, **kwargs):
import json
def print_dict_as_json(self, obj):
print(json.dumps(obj))
example_json = Json()
example_json.print_dict_as_json({"a": "string"})
Go to answer 2
Question 3
def myFun(arg1, arg3, **kwargs):
for key, value in kwargs.items():
print("%s == %s" % (key, value))
my_dict = {'arg1':1, 'arg2': 2}
myFun(**my_dict, arg3=3)
Go to answer 3
Question 4
def add_to_all_1(arr):
for i in range(len(arr)):
arr[i] +=1
def my_func():
arr = [1,2,3]
add_to_all_1(arr)
arr2 = arr
print(arr2)
my_func()
Go to answer 4
Question 5
import gc
class MyClass:
def __init__(self, name):
self.name = name
print(f"{self.name} object created")
def __del__(self):
print(f"\ncall by instance {self.name}")
print("Objects in memory after deletion:")
is_not_deleted = []
for obj in gc.get_objects():
if isinstance(obj, MyClass):
is_not_deleted.append(obj.name)
[print(f" - {name}") for name in is_not_deleted] if len(is_not_deleted) else print("nothing")
gc.enable()
obj1 = MyClass("Object1")
obj2 = MyClass("Object2")
def create_obj_3():
MyClass("Object3")
create_obj_3()
print("\nObjects in memory before deletion:")
for obj in gc.get_objects():
if isinstance(obj, MyClass):
print(f" - {obj.name}")
Go to answer 5
Answers
Answer To Question 1
If you said:
{"a": "string"}
unfortunately, you are wrong, the answer is:
AttributeError: 'dict' object has no attribute 'a'
If you like me and came from javascript first, the access dictionary (object in Javascript) is not by dot like in Javascript, you can access only by []
, and inside the key you want to set "a"
.
Answer To Question 2
If you said:
{"a": "string"}
You are wrong again, the answer is:
...
NameError: name 'json' is not define
You may know the differences between local and global scope in Python (if not you should read this: Python Scope). The __init__
is a function, the import is inside a local scope so it doesn't know what is json
. You can fix it by import it globally like this:
import json
class Json:
def print_dict_as_json(self, obj):
print(json.dumps(obj))
example_json = Json()
example_json.print_dict_as_json({"a": "string"})
Or in a more advanced way:
class Json:
import json as json
def print_dict_as_json(self, obj):
print(self.json.dumps(obj))
example_json = Json()
example_json.print_dict_as_json({"a": "string"})
You can see using import inside class for more details.
Answer To Question 3
If you said:
arg2 == 2
You are right! In Python, we have 3 ways to pass an argument:
- By the argument itself:
def myFun(arg1):
print(arg1)
myFun('arg1')
- By *args - list or tuples of arguments ( allows us to pass a variable number of non-keyword arguments to a Python function):
def myFun(*arg1):
print(*arg1)
my_tuple = ('arg1', 'arg2')
myFun(my_tuple)
- By kwargs can pass key=value arguments (kwargs allows us to pass a variable number of keyword arguments to a Python function) - like in the question. If you want to read more about the subject you can read here: freecodecamp - How to Use *args and **kwargs in Python
Answer To Question 4
The answer is:
[2, 3, 4]
For some people who know scopes and assignments, it can seem a pretty easy question. For those who don't know, python saves variable memory as a reference, so in this case, the arr
will point to a reference in a memory -> the function will change the values (but still the same reference) -> arr2
will get the reference address of arr
but after values were modified.
Answer To Question 5
The answer is:
Object1 object created
Object2 object created
Object3 object created
call by instance Object3
Objects in memory after deletion:
- Object1
- Object2
- Object3
Objects in memory before deletion:
- Object1
- Object2
call by instance Object1
Objects in memory after deletion:
nothing
call by instance Object2
Objects in memory after deletion:
nothing
It was tricky for me to understand it as well, but let's try to break it down:
- Why did Object3 call del at the beginning? The reason is simple: when Object3 was created inside the function create_obj_3(), it went out of scope as soon as the function execution finished. Python’s garbage collector identified that there were no more references to Object3, and since it was no longer in use, it triggered the del method. This is why you see Object3 being deleted immediately.
- Why do we see Object3 in "Objects in memory after deletion"? This happens because the garbage collector doesn’t delete objects immediately when they go out of scope. Objects are marked for deletion, but the actual deletion process depends on when the garbage collector runs. The gc.collect() manually triggers the garbage collection process, but it doesn't guarantee that all objects will be deleted immediately. In your case, Object3 was eligible for garbage collection, but the actual deletion may have happened later, allowing it to still be seen in the list of "objects in memory after deletion."
Points to Clarify:
- Scope of Object3: The key thing is that Object3 was created in a local scope and went out of scope when the function completed. Python then decided it could be garbage-collected.
- GC Delays: Garbage collection doesn’t always happen immediately after an object becomes unreferenced. The collection happens when the garbage collector is ready, which could be after your call to gc.collect(), depending on when Python decides to run the cleanup process
Thank you for reading this article. I hope you enjoyed and learned new things. If you have any questions or suggestions, please leave a comment.
Top comments (0)