One minor point: to make the search case-insensitive, you should really lower the input as well.
@Indently7 ай бұрын
Fair point!
@xinaesthetic7 ай бұрын
@@Indently great post, though, thanks.
@asmaamagedy98727 ай бұрын
@@Indently Thanks for every thing❤
@GitaAska-is6yz7 ай бұрын
@@Indently please tutorial full all method
@quillaja7 ай бұрын
Or better yet, casefold to deal with some non-ascii characters. Possibly unicode normalization as well for stuff like combining characters. Text is hard.
@Bwanshoom7 ай бұрын
F-strings can also show the repr of an object using the !r specifier: f"{item!r}"
@davidmurphy5637 ай бұрын
G-strings can show a lot too.
@maxdevilio7 ай бұрын
@@davidmurphy563 wtheckk😂
@DrDeuteron7 ай бұрын
Since which version? And is it pronounced bang r? Does anyone remember back quotes being assign to repr?
@nibblrrr71247 ай бұрын
@@DrDeuteron f-strings (or "formatted string literals") were added in *Python 3.6* , released end of 2016. The type converter !r to call repr() was there from the start, as proposed in PEP498 - along with !a for ascii(), and the rarely useful !s for str(). I have never thought about its pronounciation before, but I'm definitely going to use "banger" from now on. :D
@DrDeuteron7 ай бұрын
@@nibblrrr7124 don't forget unicode() from 2x, but those backward quotes `foo` -> repr(foo) were weird. Though emacs knew about them,
@rodrigodanielvittoriali66297 ай бұрын
Man! I had no idea Python could do all of this. So glad the algo picked this. Thanks for the info!
@jccorman58487 ай бұрын
1500g! What a big banana you have 😂
@DrDeuteron7 ай бұрын
one common pythonic thing is, repr(instance) should return a string so that: >>>instance == eval(repr(instance)) is True, so something _like_: return f"{type(self).___name__}(}" + ", ".join(f'{k}={v}' for k, v in self.___dict___.items()) + ")" Also: note that these dunder methods are _strongly typed_ and MUST return a str. You can also use the "dunder module" static class attribute to assist.
@poixd1ro7 ай бұрын
Your content is one of the best, I would never have imagined that __str__ was different than __repr__
@developer_anonymous7 ай бұрын
Good video, but Pyright suggest you to use `self.__class__` when instating the same class instead of using `ClassName(...)`. So in the `__or__` method you should instead return `self.__class__(...)`, and basically in every method that returns a new instance of Self. Hope it helps!
@DrDeuteron7 ай бұрын
Doesn’t type(self) work too?
@anon_y_mousse7 ай бұрын
Personally, I would require that the name representation was always lowercase anyway, even on initialization. As for fun with operators, I like to overload / on strings in languages that don't already do so to act as the split operation. Say you've got a string that's s = "foo,bar,baz,luhrmann"; then a = s / ','; would yield an array of strings containing ["foo", "bar", "baz", "luhrmann"].
@landsgevaer7 ай бұрын
Nice complement of multiplying strings! I might borrow that idea.
@DownThereForDancing7 ай бұрын
Wow I have been sitting on a use-case for union, intersection and subtraction methods for the past year but never knew the syntax could be so nice with these dunder methods (__or__ and friends). Thank you!
@pavfrang7 ай бұрын
Thank you, very intuitive and precise presentation!
@SusanAmberBruce7 ай бұрын
Two and a half kilo Apple! I did dream about such a thing when I was a kid, familiar with scrumping.
@TheWyrdSmythe7 ай бұрын
From my Java days, one rule I’ve always followed is: “Always define toString!” In Python, it’s: “Always define dunder str and repr!” It should be one of the first things you do when you write a class. (FWIW, I typically use dunder repr to return a JSON-like string, but that’s just me.)
@nibblrrr71247 ай бұрын
One rule of thumb I try to follow: eval(repr(my_object)) == my_object So repr() should give the code to construct the same (or at least an equivalent) object. This is what e.g. dataclass or namedtuple do by default. Use dunder attributes for the class name, to avoid mistakes when renaming classes or copying code: def __repr__(self): return f"{__class__.__qualname__}(x={self.x!r}, ...)" If this one-liner gets too cluttered, put the class name in a helper variable cls and use ', '.join() or linebreak-separated strings within parentheses for the constructor args/attributes. Now that I think of it, this _could_ probably be automated into a class wrapper using introspection to get the constructor signature... I guess you could use name instead of qualname, b/c AFAIU it only makes a difference with nested classes, which IMHO should make anyone pause and question their choices, anyway. :^)
@TheWyrdSmythe7 ай бұрын
@@nibblrrr7124 Yeah, that's nice! The JSON string I usually emit is something like: {classname:{attributes and values}} Which does allow reconstruction of the object from the JSON and is fairly readable when debugging.
@mudi2000a7 ай бұрын
If you use it for debugging only, __repr__ is enough, it will be automatically called also instead of __str__ if __str__ does not exist.
@ЮрийБ-о6е7 ай бұрын
Another cool video, thanks! Hope to see more ___dunders__ :)
@VoxelPrismatic7 ай бұрын
I'm just thankful I finally know what these methods are called. Every few months or so, I come up with an idea with classes, and I need to scour the internet 15min for the python documentation on all these methods.
@felo73437 ай бұрын
If you thought that was tough, imagine trying to do the same thing 15 to 20 years ago....
@rodelias93786 ай бұрын
Awesome video! Your explanation is really good! Thanks a lot!
@lemonade2345-j4e28 күн бұрын
I feel like I learned more than expected, which is always good.
@workingguy31667 ай бұрын
Man this is crazy helpful, this is some advanced stuff
@Shaxzodbek167 ай бұрын
you do it so useful for all of us. I know what you are one of the best python developer.
@chandrasekars89047 ай бұрын
This is really an excellent channel on Python like "techie talkee"
@Mefodii7 ай бұрын
Great video, thanks One extra thing which I learned was that you can do filter with list comprehension. Until now I did filter + lambda (which basically was shooting myself in the leg because of whacky annotations).Thanks again
@dbottesi7 ай бұрын
another great video thumbs up!!
@mikerico61757 ай бұрын
The __repr line 11, you can just do return f ‘{value =}’ instead of f ‘value = {value }’ . Also, for the __get_item lines 28 29
@jesusromero91677 ай бұрын
Great video!
@kristerl9397 ай бұрын
Like this and I agree with @xinaesthetic about the input should be also be converted. But you should use 'casefold()' instead of 'lower()', in these examples it might not matter but it should always be used when a comparison is made. Keep up with the videos.
@williamsquires30707 ай бұрын
(@3:30) This raises several questions: 1) wouldn’t this implementation of the __eq__ dunder method make it compare the addresses of the two dictionaries? 2) can you change the value of the instance’s values through the dictionary, with the __dict__ dunder method? That is, if you change the value associated with the key, ‘grams’, will it change the instance’s ‘grams’ property to that new value, or only the dictionary?
@DrDeuteron7 ай бұрын
What’s great about python is that you can test it in an interpreter about as fast as you can answer the question.
@nibblrrr71247 ай бұрын
1) No, because == on the default collections (dict, list, set, ...) compares their contents by value. Use the *is* operator for checking for identity, i.e. whether they're literally referring to the same object in memory. 2) Yes, at least for normal user-defined classes (AFAIU classes can use slots instead of a class dict; also @property attributes might be an issue). Please don't, as it's hella confusing. But as Raymond Hettinger puts it: "Python is a language for consenting adults." (See also: Why are there no private methods?)
@SciChronicleUniverse7 ай бұрын
really knowledgeful
@krzysiekkrzysiek90597 ай бұрын
If I do order with subscriptions, this channel stays. Great kind of practical tutorial 🔥
@dipeshsamrawat79577 ай бұрын
Nice. Keep it up. 💯
@ladislavhusty94666 ай бұрын
You could also define the dunder method __iter__ for class Basket to make it iterable as well
@stefanocardarelli92017 ай бұрын
Thanks alot for the quality content you provide! One question: what is the extension that shows you classes and methods usages throughout code? When coding rust that thing is auto enabled (thanks to the compiler features I guess)… thanks in advance :)
@rezanabulsi32207 ай бұрын
Heya, just wanted to ask what theme you're using. Still fairly new to Python and loving the content so far
@aliakbarsobhanpour84707 ай бұрын
that was awesome.
@rishiraj25487 ай бұрын
Great thanks
@robsonjunior24835 ай бұрын
Hi, To combine dictionaries, sets, classes, etc... should not be an and operator? Something like this: d1 & d2 Instead of d1 | d2 And the magic method would be __and__ Thanks.
@Edurolp7 ай бұрын
Great video :D btw you have some big bananas in there!
@davidl33837 ай бұрын
thanks a lot
@LC-uh8ifАй бұрын
The first one takes me back to Intro to JAVA in College...having to create an equals method for every class.
@felicytatomaszewska7 ай бұрын
Very nice … can you please do videos on testing
@y2ksw14 ай бұрын
Shouldn't you use Fruit instead of Self, in order to view correctly the required type during comparison in method 1?
@AtselWarawara7 ай бұрын
I'm new to python, is there any version requirements or restrictions to use these Dunder methods?
@landsgevaer7 ай бұрын
Don't think so (post python2 i presume?)
@AtselWarawara7 ай бұрын
@@landsgevaer yes, I use 3.10 however I need compatibility to 3.7 and 3.8
@Anomaa7 ай бұрын
I'm not a fan of most dunder methods (specifically for operators) most of the time since they drastically reduce understanding of the code. For example at 7:33, to try to guess in advance what will be displayed, we must: - know that the syntax "|" is related to the dunder method "__or__" - read the documentation/source code A function/method/classmethod anything else actually with an explicit name (like "combine") and a good docstring would be so much more readable
@DrDeuteron7 ай бұрын
For me, I love overloading operators, until I want to see where something happens in the code.
@Raugturi7 ай бұрын
Also it's weird to have "__or__" method that's not commutative. I would not expect `a | b == b | a` to return False and here it will. Edit: Fixed based on @mudi2000a comment.
@thomaseb977 ай бұрын
certain functionality is fine for dunder methods, basically where they are self explainatory, __str__ is a simple expectation, __eq__ aswell an example where __add__ and other mathmatical operators is fine to overload is for example a Point class which just represents multiple numbers basically use dunder methods where its extremely clear what it does under the hood by just knowing what the class represents without looking at the actual implementation
@nibblrrr71247 ай бұрын
I disagree with your first point (that it's not obvious that the "|" operator calls "__or__"), as that is just being familiar with Python. That ship has sailed with "__init__", hasn't it? (The fact that we have come to accept how messed-up and confusing constructor syntax in C++/Java is another topic...) However, I do agree that unless the meaning is obvious - like the interfaces from collections.abc, or behaving similarly to builtin datatypes ("+" for concatenation, like with str or list) - or well-documented and signposted, you're probably better off using regular methods and make the users write more explicit calls.
@mudi2000a7 ай бұрын
@@Raugturi You mean commutative.
@artygor25247 ай бұрын
Nice tutorial, except for the part where you did basket: Basket = (fruit = fruit), that was the equivalent of calling a string just "string" and it really confused me
@Alchemist102417 ай бұрын
Didn't know we can specify the return type in Python, thanks
@sarimbinwaseem7 ай бұрын
And you can return a different type regardless of the specification... 😄
@Alchemist102417 ай бұрын
@@sarimbinwaseem hmmm interesting
@DrDeuteron7 ай бұрын
Every thing is a first class object in python
@jimstanley_493 ай бұрын
Type hinting is just for your code editor to flag you when you try to use a string method on the results of a function you hinted should be an integer. If you don't fix it, the interpreter will still try to run it. Sometimes it will fail immediately, like my example, or be buggy in subtle ways where the operations overlap.
@PerfectArmonic7 ай бұрын
Where can i Find a comprehensive list of all python dunder methods?
@MeHdi.fz287 ай бұрын
Python document webpage
@landsgevaer7 ай бұрын
Google "list of all dunder methods in python" disappointed you?
@zoookx7 ай бұрын
9:11 my grandmother is a developer. She can read both.
@pro.elisei7 ай бұрын
(1) It gives me an error when I annotate 'other' with 'Fruit' or 'Self' at or and repr Dunder Methods (e.g. def __or__(self, other: Fruit) -> Fruit:)... it says „NameError: name 'Fruit' is not defined”. It works only with 'object' (def __or__(self, other: object) -> object:). And if I write 'object', PyCharm warns me at 'combined: Fruit = apple | orange | banana' -> expected object type Fruit :)) Any thoughts? Thanks! and (2) If you want to use __format__ and __str__ / __repr__ at the same time, it won't work. It raises the error from __fomat__ match _: ValueError: Unknown format specifier... You will have to specify the desc match to work - print(f'str: {fruit:desc}') P.S. I found your videos recently and it's a pleasure watching them. Keep it up! ❤
@landsgevaer7 ай бұрын
Without checking: from __future__ import annotations and/or from typing import Self
@TomLeg7 ай бұрын
It's important to prioritize your fruits 🙂
@matthewbay19787 ай бұрын
I just imagine an Easter egg in all of their code where if you add 'banana' to the end of an input, it will show an ASCII art banana for 5 seconds before moving on to the actual functionality of the code.
@vanka_feelgood30007 ай бұрын
I think Self in the __eq__ is not correct. In general, we can compare with any object, just need to return False if the other object is not the instance of the class
@DrDeuteron7 ай бұрын
Luckily type hints don’t matter
@loo_97 ай бұрын
begone javascript sympathizer. although python does not enforce it, you should not be using the == operator on objects of different types. if you want to compare objects and but are not sure the type, your problems are much deeper
@exkalybur_dev7 ай бұрын
I'm learning English. I'd like to know where are you or where come from your accent. Please. Thanks a lot.
@landsgevaer7 ай бұрын
Sounds German(ic).
@artmolnar42452 ай бұрын
The syntactically correct way to create a variable : f1 = Fruit(...) So the "f1: Fruit = Fruit(...)." is incorrect therefore I do not understand how the "f1: " part works here as "alias".
@kyrgyzsanjar7 ай бұрын
What is the name of that assigment style with colon? apple: Fruit = Fruit(name="", grams=) What's different vs. apple = Fruit(....)?
@anon_y_mousse7 ай бұрын
It's a type annotation. I was just playing around with the interpreter and it doesn't prevent me from assigning other types to a variable, so I'm not really sure what the point is other than to provide documentation for anyone reading the source code, but if you just call a constructor like that it's redundant for seemingly no reason. Maybe someone more knowledgeable about Python can correct us both, but for what it's worth, I wouldn't bother unless the declaration is separate from your first initialization of a variable.
@kyrgyzsanjar7 ай бұрын
@@anon_y_mousse oh got it! Yeah makes sense!
@cookie_space6 ай бұрын
It doesn't prevent you of assigning anything else but it will show you a warning for it. Also it enables your IDE to include the appropriate methods that are associated with that type in the auto-complete list.
@anon_y_mousse6 ай бұрын
@@cookie_space I don't use an IDE. It's either vim or the python3 interpreter from the command line whenever I use it. The only time I've discovered that it actually errs is when used for parameter typing for functions, but I guess warnings will have to suffice for other uses. It would be nice if Python would use it to prevent assignment of unequal types, but in a language that treats variables as *really* variable, that's probably asking too much.
@BersekViking7 ай бұрын
That was one big banana. :)
@thousandsunny1007 ай бұрын
I get this error on the first example, "NameError: name 'Self' is not defined".
@johnraz997 ай бұрын
Did you include the first line: from typing import Self Because I'm using Python 3.10, I had to include: from typing_extensions import Self
@thousandsunny1007 ай бұрын
@@johnraz99 totally missed it. Thanks!
@DebashishGhoshOfficial7 ай бұрын
What if I do apple | apple ?
@landsgevaer7 ай бұрын
Fruit(name="apple & apple", grams=2000.0) the way he implemented it (I don't remember the weight).
@WiktorWandachowicz7 ай бұрын
😅With regard to *__eq__* "double underscore" method (hence the name "dunder") you really should mention that it compares two OBJECTS here, not CLASSES... For obvious reasons objects are instances of classes, not "aliases" like you have said in the first part 😉 That said, this material is still worthwhile. But my university ears just hurt when such mistakes are done. Best regards and thanks!
@MyrLin87 ай бұрын
Is there a 'head' method? ;)
@DrDeuteron7 ай бұрын
No, but there is a mifflin
@landsgevaer7 ай бұрын
Pandas dataframes have a head method; not dunder though...
@sunj83464 ай бұрын
operator overloading
@AsherGene-uw6hk7 ай бұрын
Second
@rondamon44087 ай бұрын
What's your microphone brand/model? It sounds amazing!
@Indently7 ай бұрын
It's the Røde NT USB
@rondamon44087 ай бұрын
@@Indently merci
@AAI_Einstein7 ай бұрын
4:30 when were these keywords added?😂
@TheWyrdSmythe7 ай бұрын
Oof, da! I would _never_ redefine get _item_ to return a list. For that, add another method with a better name. And you need to .lower() the item, too!
@মন্দির-ধ৭ণ7 ай бұрын
I love you infinite percent
@diogolscc7 ай бұрын
first
@iestyn1297 ай бұрын
Did you mean to use ‘fruit.name.lower() == item.lower()’? I’m just checking because it sounded like you meant to do that lol
@Indently7 ай бұрын
Yes, as someone else pointed, I only did half the job there xD
@willyyeremi52847 ай бұрын
when i reach the __getitem__ section, i only think "fruit for fruit inside fruit, idk man, can i just eat all of it???"
@jeviwaugh97917 ай бұрын
third
@vaulttectradingco84387 ай бұрын
Discord gang
@AsgerJon6 ай бұрын
__prepare__
@Rusvi16 ай бұрын
Thank you.
@DrDeuteron7 ай бұрын
its dunder getitem, not get_item.
@Indently7 ай бұрын
Thank you, I have updated both the thumbnail and description!
@mikerico61757 ай бұрын
f ‘{value =}’
@iestyn1297 ай бұрын
🐟
@i7Solutions7 ай бұрын
your way of writing variables with type hinting really confused me
@dfields95114 ай бұрын
🍌
@MarianoBustos-i1f7 ай бұрын
Man, those tooltips are extremely annoying. They distract me a lot from reading the code as you type it.
@DrDeuteron7 ай бұрын
Do you mean the annotations? Like: Twopi : float = three: int + 0.1 : float + 41: int / pow(10: int, 3: int) ? Yes. And telling ppl dunder init returns None, I just can’t. Of dunder str returns str. Same for int, float, complex, etc….
@MarianoBustos-i1f7 ай бұрын
@@DrDeuteron No. I just meant the IDE tooltips
@DrDeuteron7 ай бұрын
@@MarianoBustos-i1f oh. Yes, I turn those off all the time, esp when I'm writing a line that depends the prior line... ...it opens up and hides what I want to build off of and tells me a bunch of stuff I don't need to know.
@sebskyYyy2 ай бұрын
too confusing
@lǎozǐ-thefirstofhisname7 ай бұрын
I do not recomend any python user see this video. Several things of python 1 (still are teached and mixed with Cobol or other grosser language anyway…