Python's Magic Methods in Classes (Summary)
You now know how to customize your classes using special methods, also known as magic methods or dunder methods in Python. These methods support core object-oriented features in Python, so learning about them is a fundamental skill for Python programmers who want to create powerful classes in their code.
In this video course, you’ve learned:
- What Python’s special or magic methods are
- What the magic behind magic methods in Python is
- How to use special methods to customize different class’s behaviors
With this knowledge, you’re now ready to deeply customize your own Python classes by leveraging the power of special methods in your code.
Congratulations, you made it to the end of the course! What’s your #1 takeaway or favorite thing you learned? How are you going to put your newfound skills to use? Leave a comment in the discussion section and let us know.
00:00 Congratulations, you made it to the end of this video course.
00:04
You accomplished a lot in this video course. You learned what magic methods are and how to implement them, you customized new instances with the __new__
magic method, you created user-friendly string representations with the __str__
magic method, and developer-friendly ones with the __repr__
magic method.
00:26
You also reviewed how iterables and iterators work and how to create a customized one, you made objects callable with the __call__
dunder method.
00:38 Check out these two resources to solidify your knowledge. You can check out “Single and Double Underscores in Python Names” to figure out what’s their difference and also, you can check out “Python’s Magic Methods: Leverage Their Power in Your Classes” interactive quiz to test yourself.
00:58 Thank you for sticking along and finishing this video course. I hope this is how you feel about magic methods now. Tell us in the comments what you think about this video course and hope to see you soon.
bhchurch6 on Nov. 6, 2024
I created the Storage class without saving the ‘value’ attribute in the instance since it should have been created by the super().__new__(class, value)
.
class Storage(float):
def __new__(cls, value, unit):
instance = super().__new__(cls, value)
instance.unit = unit
return instance
def __str__(self):
return f'{super().__repr__()} {self.unit}'
When I created the object >>> storage_size = Storage(512, 'GB')
, entering just storage_size
in the repl, the value ‘512’ was printed out. So the value was available from the object. Using the print()
function, the output was 5120 GB as per the __str__
method.
When I tried to create the __repr__
method in a similar fashion, I got a recursion error. With my modified class object, how do I get the underlying float value from the inherited class from the __repr__
method’s ‘self’ object. I thought that including an instance.value attribute was essentially duplicating the underlying float value provided by the inherited class.
ole088 on Nov. 12, 2024
Great course, Negar!! I like how you introduced and explained things. I have used some of these magic methods in the past, but will be using them more in the future. I look forward to more courses from you!
Andras on Jan. 10, 2025
@bhchurch6 I did the same implementation and added a comment to that chapter of the course, not yet having seen your comment above.
“I thought that including an instance.value attribute was essentially duplicating the underlying float value provided by the inherited class.” - I fully agree.
I also ran into the recursion error and posted this on SO. Hope it helps.
Become a Member to join the conversation.
taniferf on Oct. 30, 2024
For me, the biggest take away is the understanding of ‘init()’ and the ‘str()’ dunder methods.