Python's collections.abc | InvertibleDict

  Рет қаралды 46,103

mCoding

mCoding

Күн бұрын

Пікірлер
@tylerfusco7495
@tylerfusco7495 Жыл бұрын
It took me so long to understand covariance and contravariance of type variables, and honestly I would love to see you explain it, just so more people understand how powerful of a concept it really is
@vidhanio
@vidhanio Жыл бұрын
this is not python, rather rust. still a very useful video, and helped me a lot: kzbin.info/www/bejne/n4e8iHd_jJxkoM0
@tytywuu
@tytywuu Жыл бұрын
I don’t fully understand type hinting beyond basic usages. Feel so anticipated too see one tutorial about them from mcoding!!
@Adowrath
@Adowrath Жыл бұрын
I always use the helper analogy of: Covariant means something of that type can "come out" (via return value), contravariant means it can "contract" something of that type (via parameter e.g.). Another more technical way is that the less confusing sounding name (covariance) just preserves inheritance, while the more confusing one (contravariance) inverts it fully.
@user-hk3ej4hk7m
@user-hk3ej4hk7m Жыл бұрын
Covariance and contravariance are useful when you need mutable mappings, which most of the time is not the case. It's sad that we don't have an immutable dict type where we don't have to deal with these complexities. Also hashing would be nice
@knut-olaihelgesen3608
@knut-olaihelgesen3608 Жыл бұрын
Every time I see you have posted, I just know there will be a high quality video on an advanced topic. Love that.
@davea136
@davea136 Жыл бұрын
After surveying many python instruction channels on youtube I can confidently sayths is the best channel to learn about interesting facets of python programming. Your content should be sponsored by somebody like Khan Academy or LeetCode. I am baffled that you do not have more subscribers. Thank you for all of your efforts!
@mCoding
@mCoding Жыл бұрын
Thank you very much, I appreciate it!
@problemat1que
@problemat1que Жыл бұрын
Excited for the 15 parts series j/k. Would love to see a discussion of covariance and contravariance for python, ty! Love #pycharm
@PraecorLoth970
@PraecorLoth970 Жыл бұрын
I've actually had a situations where an InvertibleDict would've been useful. And I'm glad typehints are optional. Great for when you're building something bigger or sharing code with others. But if I just want to get some data analysis code, it's great to not have to worry about all those intricacies. #pycharm
@lxathu
@lxathu Жыл бұрын
It happens more frequently than one would think at first glance. Allowing the use of one shortened or abbreviated version of an identifier is quite common and and expected convenience feature.
@markracsko8414
@markracsko8414 Жыл бұрын
Knowing about this invertible dictionary stuff would have been tremendously useful to me on pretty much the first python project I undertook on my own. I was building a simulator for the Enigma machine from WW2. Spent more than half a day trying to figure out how to make the forward and backward dictionaries of the Enigma's rotors behave correctly when the rotor steps before encrypting each character of the plaintext. Ended up throwing in the towel and just generating the backwards dictionary on the fly when it was needed using a dictionary comprehension. Although using this InvertibleDict approach would have made my code longer, so maybe what I came up with ended up being better.
@bolzenguido1722
@bolzenguido1722 Жыл бұрын
I recently came across the exact situation you describe and found it quite unsatisfying to manually define two dicts that are inverses of each other. This is very elegant, thanks a lot! #pycharm
@felipedidio4698
@felipedidio4698 Жыл бұрын
This channel has the best videos for serious programmers #pycharm
@vidhanio
@vidhanio Жыл бұрын
Why would you use .register, even if you implement everything yourself? Is there any downside to inheriting and overriding everything?
@mCoding
@mCoding Жыл бұрын
One downside is that inheriting from an ABC changes the metaclass to ABCMeta, which may conflict with other metaclass stuff you (or your users) are doing, or you may just want to avoid metaclasses. Additionally, many of collections ABCs use multiple inheritance (Collection inherits from Sized, Iterable, and Container), which is another thing that some people prefer to avoid.
@vidhanio
@vidhanio Жыл бұрын
@@mCoding Interesting, thank you very much!
@andreashermansen6061
@andreashermansen6061 Жыл бұрын
At around 5:25 you mentioned that one could be in a situation where you can't inherit from some class. I have a hard time imagining what that would be, you don't by any chance have an example of that?
@mCoding
@mCoding Жыл бұрын
There are many reasons! It could be for efficiency like if you are writing a C extension class, inheriting from a Python class could ruin it. It could be because you are using metaclasses and inheriting from an ABC would cause a TypeError because the metaclasses are different (inheriting from ABC changes the metaclass to ABCMeta, and metaclasses of derived classes must be subclasses of the metaclasses of all bases). It could be because your boss told you to use your company's internal BetterMappingInterface as the base class. It could be because you are trying to avoid multiple inheritance (Collection inherits from Sized, Iterable, and Container!).
@lex_darlog_fun
@lex_darlog_fun Жыл бұрын
Actually, the part you omitted would be the most interesting to watch. I hope there will be a part 2 of this video.
@SamuelDavenport-h8v
@SamuelDavenport-h8v Жыл бұрын
Your explanation of ABC's was very good, I didn't know you could register classes to be counted as instances of ABC's. That makes me interested in how that's accomplished under the hood. I look forward to your explanation of covarient and contravarient types. #pycharm
@kalelsoffspring
@kalelsoffspring Жыл бұрын
I've been programming for a while and only this month had a reason to look up what covariance is for typing, it's pretty neat but I definitely understand why you glossed over that :P In general I prefer interfaces to this direct inheritance as many languages only support one parent class, but as Python is Python I do appreciate what they offer with the ABCs
@KappakIaus
@KappakIaus Жыл бұрын
Great video: Nice summary of the basic concept, sprinkled with interesting sidenotes (e.g. i didnt know about the convention for hidden arguments)! Deliberately won't write the hashtag to avoid lowering the chance for people who would make better use of the license than me. 😊
@kristiandilov5249
@kristiandilov5249 Жыл бұрын
The GOAT of Python has returned!
@coarse_snad
@coarse_snad Жыл бұрын
It's fun to see you present real python programming. As an example, in a codebase i maintain there is currently a very long block comment with several examples to try to explain why a type[ignore] is required on a specific line. The block comment links to several github issues for various projects that are part of python, none of which are closed yet. A good explanation of variance is hard to come by, so i would be very interested to see your possible future video on it. It's an important subject that many languages try to ignore, sadly.
@PeterZaitcev
@PeterZaitcev Жыл бұрын
In your implementation, the constructor always copies reference to the forward argument, even if backward isn't given. This can lead to the strange behavior when you create InversibleDict from other mapping and mutate one of them. Furthermore, if the original mapping was immutable, you'll get an error. I suppose #pycharm won't highlight that kind of error.
@coarse_snad
@coarse_snad Жыл бұрын
I think the subtlety here is that the __init__ takes in _forward by-value, not by reference. In rust, this is very explicit. C++ also has an explicit way to specify this. I suppose it is a feature we cannot easily get in python however. The implementation and type hinting for __init__ is technically correct (sound), but it is misleading. So I guess it is not actually correct in practice.
@mCoding
@mCoding Жыл бұрын
Hey that's a good point! In this example I made InvertibleDict assume ownership of the dict you pass in. Instead, you could make a copy of the forward dict if the backward one wasn't provided.
@PeterZaitcev
@PeterZaitcev Жыл бұрын
@@coarse_snad all classes in Python are copied by reference unless explicitly stated the opposite. Otherwise, the interpreter would have to handle return-value-optimisations which is incredibly hard to implement in the dynamic language. And when impossible, each stack call would almost double the memory required for the program to run.
@Jason-b9t
@Jason-b9t Жыл бұрын
For the interfaces commonly used in Python, it is very convenient to use the abc module. But as far as I know most of the time you only need to use Protocol to type hint duck type custom classes. #pycharm
@yolosaurusrex90
@yolosaurusrex90 Жыл бұрын
thanks again for keeping up with the intermediate-advanced Python videos. much appreciated. #pycharm
@josephparkes6412
@josephparkes6412 Жыл бұрын
Would it be possible to create an invertable dict that allows for multiple keys to have the same value? If you wanted to return the keys for a certain value it would be value: list(keys) ?
@mariuz-xn9pi
@mariuz-xn9pi Жыл бұрын
Very interesting video. I got one question: Why does changing the value in the inverse dict change the value in the "original" one? The inverse "inv" property creates a new instance and therefore instanciates the new class with copies from the "old" instance. Changing values in here shouldn't affect the "old" instance. What am I missing out?
@anon_y_mousse
@anon_y_mousse Жыл бұрын
It's because he's using a reference. It'd be easier to understand if more explicit syntax was used.
@mariuz-xn9pi
@mariuz-xn9pi Жыл бұрын
Thanks for your answer. As far as i know python doesnt support references or pass by reference. Could you rewrite the part you are talking about for me more explixit? That would realy help.
@mCoding
@mCoding Жыл бұрын
This is because d and d inv are sharing the same underlying forward and backward dicts, just swapped. This is just like if you have a=d and b=d, then changing a[1] is also changing b[1].
@mariuz-xn9pi
@mariuz-xn9pi Жыл бұрын
@@mCoding Thank you for the answer. I tried it in a sample code and its very interesting. E.g. When I pass a list to a function and change that list in the function without returning anything, the list in the main scope changes. too I always thought the arguments get copied and don't affect the main scope. Seems like a way for functions to return values (append to a list defined in the main scope and passed as argument) without the need of an explicit return statement. Very interesting.
@jpay
@jpay Жыл бұрын
In the situation where two keys have the same value (9:30), why throw an error instead of deleting the old key/value pair from each dictionary? This is what you do in the next case. Wouldn't this also preserve the enforced bijection? This seems to help, but I can't pin down why... #pycharm
@mCoding
@mCoding Жыл бұрын
Great question! It's totally up to you how you want your map to act and I even coded that version up too. Personally I decided that d[k] = v deleting a key unrelated to k would be very confusing behavior that would make InvertibleDict not fit my mental model of how a dict should act. If you prefer it a different way, feel free to change the implementation accordingly 😉
@jpay
@jpay Жыл бұрын
@@mCoding Gotcha! I also suppose that throwing an error allows the user to decided when (or if) the unrelated key is deleted. It seems, as always, different implementations for different use cases. Thanks :)
@chndrl5649
@chndrl5649 Жыл бұрын
Typehinting and strict data thpe restriction are something really useful for any level of collaboration of project.
@knut-olaihelgesen3608
@knut-olaihelgesen3608 Жыл бұрын
A video on the typing module and some advanced use cases? Like annotating a mixin class?
@SaiponathGames
@SaiponathGames Жыл бұрын
Pretty good video regarding ABCs, I have been using ABCs for quite a while now, yet this video dived a little deeper into the topic and I learnt a lot more than what I wished I would have learnt earlier! #pycharm
@kamilos956io
@kamilos956io Жыл бұрын
These are more and more advanced topics. I'm so glad, keep it up! #pycharm
@matteolacki4533
@matteolacki4533 Жыл бұрын
Hello, great video! One little thing: likely it would be more effivcient to cache the .inv method to avoid recreating the class each time one wants an inversely mapped element? Or am I missing something here? Best wishes!
@EvanBerkowitz
@EvanBerkowitz Жыл бұрын
People go crazy with type hinting. But seeing how #pycharm can use it to infer autocomplete suggestions is pretty slick!
@AbstractObserver
@AbstractObserver Жыл бұрын
I've has multiple problems with typehinting when using "set/tuple/list/dict" instead of using those from the typing library "Set/Tuple/List/Dict", is it a behavior for newer pythons? I am kinda atuck in 3.9 bc aws wont update the lambda runtimes
@mCoding
@mCoding Жыл бұрын
The lowercase ones were introduced in 3.9 so you should be ok. The uppercase ones are deprecated and may disappear in the future. Functionally they are the same, but it is recommended you transition to the lowercase ones as you upgrade your Python.
@LolKillization
@LolKillization Жыл бұрын
could someone tell me what line 26 does at 7:35, please? i have never seen this before and am very intrigued
@mCoding
@mCoding Жыл бұрын
Absolutely! I've got a whole video on keyword-only and positional-only args! kzbin.info/www/bejne/iGmQoHSneMx7l8k
@jameswise9171
@jameswise9171 Жыл бұрын
It's pretty much Rust traits! Complete with default implementations! Very cool!
@coarse_snad
@coarse_snad Жыл бұрын
The student becomes the teacher. Good to see languages develop together :D
@sinkingboat101
@sinkingboat101 11 ай бұрын
Can't wait for the other 14 parts! :D :D
@spencercain2035
@spencercain2035 Жыл бұрын
When you define the inv function, you call self.class(self._backward, _backward=self._forward). Does this instantiate a new class with ~references~ to the same _forward and _backward objects in memory, or does this copy those objects? I'm wondering if there are unneeded, repeated computations every time the inv function is called.
@mCoding
@mCoding Жыл бұрын
The original and the inverse share the same underlying dictionaries so the data in the dictionaries are not copied.
@aaronm6675
@aaronm6675 Жыл бұрын
This was a fantastic sample use case; big brain, very instructive #pycharm
@krestofelo8757
@krestofelo8757 Жыл бұрын
Love your videos! Watching them whole, so couldn't miss the note about secret #pycharm contest ;)
@secozzi2111
@secozzi2111 Жыл бұрын
It's a shame you joked about making this a 15-part series, I would definitely watch all of it ;) #pycharm
@raphaelcunha5208
@raphaelcunha5208 Жыл бұрын
An invertible dictionary is really a great idea. I had two implement a two way mapping before but I used two dicts. Your solution looks definitely cleaner. #pycharm
@alexismandelias
@alexismandelias Жыл бұрын
I mean... he also uses 2 dicts here...
@ethanyalejaffe5234
@ethanyalejaffe5234 Жыл бұрын
When implementing __setitem__, why do you use a paradigm of creating a dummy missing object instead of just checking if value in self._backward and self.backward[value] != key? It's one fewer O(1) check, but it seems less readable. #pycharm
@mCoding
@mCoding Жыл бұрын
Hashing an element is not necessarily O(1), it can be arbitrarily complex, which is why it's generally recommended to hash only when necessary. Although in real code with normal types it probably doesn't make any noticeable difference. I don't find the dummy missing any less readable, it's really up to taste, feel free to implement it however it makes the most sense to you. The MutableMapping ABC prefers to wrap everything in try: except KeyError: everywhere, which is another fine alternative to both your and my suggestion.
@alexlombardi1790
@alexlombardi1790 Жыл бұрын
Thanks for the great chanel and content #pycharm
@brighamhellewell6479
@brighamhellewell6479 Жыл бұрын
#pycharm I realy like how you have taught me more on how to write better code.
@JaredJeyaretnam
@JaredJeyaretnam Жыл бұрын
Have you ever thought about doing Julia videos? I’m trying to get into the language but I’ve realised I learnt so much Python on here and I don’t have the same resources to teach me the idiosyncrasies and pitfalls of Julia! So I’m just floundering in the dark poring over dense documentation.
@POINTS2
@POINTS2 Жыл бұрын
Secret giveaway? I think you mean _giveaway
@mCoding
@mCoding Жыл бұрын
I lol'd
@hassaanalansary
@hassaanalansary Жыл бұрын
I would love to see a video on covariant and contravariant and how it may affect autocomplete in #pycharm
@tntmaster3708
@tntmaster3708 Жыл бұрын
This is an interesting dive into the abc module. I only recently started using aspects of abc (I'm using abstractmethod for a class structure), and this video made me want to implement complex interfaces into my own code, LOL. Great video as always! #pycharm
@gehrehmee
@gehrehmee Жыл бұрын
One thought here -- the pattern of a dict's init taking a dict as a parameter is that it makes a COPY of the dictionary. What you've done here makes an IterableDict that references the dictionary passed in. That might not seem like a big deal -- but you've gone to some lengths to maintain the invariant conditions here, and there's nothing to stop the caller from modifying the dictionary they gave you after the fact, breaking that. You might want to instead make a copy of a dict if an external client passes one in, but have both _forward and _backward internal parameters you can use where you can trust they're not something somebody is (in good faith) passing in normally with dict-inspired expectations that don't line up with the implementation.
@mCoding
@mCoding 11 ай бұрын
Great point! If i ever pull this out into a repo, i'll be sure to be more careful about copy/ref.
@mikedecherd8666
@mikedecherd8666 Жыл бұрын
Thanks for the great content on advanced topics. #pycharm
@AntonioZL
@AntonioZL Жыл бұрын
'Hey, kids! Today we're going to learn the ABC! That's right, little TImmy, Abstract Base Classed!!'
@mCoding
@mCoding Жыл бұрын
Timmy didn't realize his life was set down a different path that day.
@mad_vegan
@mad_vegan Жыл бұрын
1:45 I think the "I won't modify you" is wrong. Sequence, Set, and Mapping can be mutable. If you do "isinstance" with list and tuple against Sequence and MutableSequence, the only one that is False is tuple against MutableSequence.
@mCoding
@mCoding Жыл бұрын
Great observation and this is a subtle point. Type annotations are not checked by Python and so their meaning is highly dependent on who is using them. Different people can hold themselves and their team to different standards regarding how they are used and whichever standard you prefer to use is up to you. Read another way, it's often unspoken rules that dictate what they mean. Most people agree that b: B means b should be an instance of B, either literally in the sense of passing an isinstance check or structurally for ABCs and Protocols. So at the bare minimum d: Mapping means d should be a Mapping. As you point out, being a Mapping doesn't mean you aren't also a MutableMapping, so code that takes your Mapping, checks to see if it is a MutableMapping using isinstance, and then mutates it is technically allowed because you checked the type. However, there's a stricter level of interpretation for d: Mapping, that you promise to program only against the Mapping *interface*. If you hold yourself to the standard of programming against the Mapping interface, checking to see if your argument is a MutableMapping and then mutating it would certainly be unwelcome behavior :), even though it is not going to error at runtime. So a common unspoken rule here is that if you type hinted d : Mapping, you aren't going to call any mutating methods even if they exist, and that if you really wanted to mutate the mapping, you would have typed it as MutableMapping. Again, this is pure convention and many people do not abide by this convention, but that convention is what I was tacitly using here when I said "I won't modify you". It's not that I can't modify you, it's that if I intended to call any modifying methods I would have used MutableMapping.
@mad_vegan
@mad_vegan Жыл бұрын
@mCoding Oh, I see. That makes a lot of sense now. Thanks for the explanation.
@caneplayz
@caneplayz Жыл бұрын
So happy to have discovered your channel #pycharm
@sophigenitor
@sophigenitor Жыл бұрын
Besides the interesting and great explanations, the example you give, an invertible dict looks very useful in many situations and projects. How do you organize such things? Do you create a package for each such self contained utility? Do you have a private "helpers" package that contains all such utilities? Or do you copy paste them into each and every project that uses it?
@mCoding
@mCoding 11 ай бұрын
Typically, you would publish the utility as a package on either pypi or your company's private internal pypi server.
@oriperry
@oriperry Жыл бұрын
Do you usaully use a theme when you use #pycharm?
@mCoding
@mCoding Жыл бұрын
Just the default Darcula with a few font color changes to make them more readable on screen (e.g. made __dunder__ variables pink instead of dark purple).
@Obie.
@Obie. Жыл бұрын
Once again another useful video!! #pycharm
@Maximetoussaintmusic
@Maximetoussaintmusic Жыл бұрын
Very interesting video, as always! Always learning a lot from you on this channel! #pycharm
@Voidk7
@Voidk7 Жыл бұрын
Great video as always! Can you make a video on function/method overload in Python? There are options such as singledispatch, multipledispatch, multimethod and even typing module has an overload decorator
@mahmudhasan3093
@mahmudhasan3093 Жыл бұрын
Can somebody explain the difference between interfaces and abstract classes in the context of python?
@trag1czny
@trag1czny Жыл бұрын
one of my favorite videos of yours :) great job! early access gang 🤙
@georgplaz
@georgplaz Жыл бұрын
Great example! I think the name BijectiveDict or BidirectionalDict would have been better names though. It instantly communicates the underlying mathematical principal
@mCoding
@mCoding 11 ай бұрын
I agree! Unfortunately, i've learned the hard way that it's not good to assume programmers know the word bijective. That's why I went with invertible.
@gexahedrop8923
@gexahedrop8923 Жыл бұрын
thanks, would be also interesting to hear about covariant/contravariant typing #pycharm
@nieznanywinternetach
@nieznanywinternetach Жыл бұрын
Great video! I recently used similar functionality via bidict library in my commission, where I mapped ids to user search queries for fast bidirectional look-up. Pretty useful tool And as fun-fact about #pycharm, did you know that the IDE marks type of monkey-patched function arguments as name of functions it used? In my case it's been "acurs: {execute, fetchall} = None". I discovered it when refactoring the boilerplate code of database connections, as I used context managers for auto-commiting and closing them. With a simple decorator factory and an extra argument for functions using it, I could avoid 2 extra indentation levels and get full access to the DB - and the code looks so much better 👍
@oscartheodorius1122
@oscartheodorius1122 Жыл бұрын
That video is interesting, despite not being the level of Python I need daily #pycharm
@michelepiazza3601
@michelepiazza3601 Жыл бұрын
I really like your explanations and videos. They make me want to get deeper into topics and learn more. Of course I would love to have a chance to get those juicy #pycharm redeemable licence codes. Keep up the good work!
@mCoding
@mCoding Жыл бұрын
Thanks very much and luck is on your side today because you will soon be the owner of one of those juicy #pycharm license codes! Email me to claim.
@MilesLuigi
@MilesLuigi Жыл бұрын
This is awesome, I have a use case where I have separate databases where I want to map one table's primary keys to the other table's primary keys. #pycharm
@berkozsoy
@berkozsoy Жыл бұрын
#pycharm i would watch 15 part of this :)
@nocturnomedieval
@nocturnomedieval Жыл бұрын
Great content as always. Would love to hear your pov on mojo and codon #pycharm
@EW-mb1ih
@EW-mb1ih 8 ай бұрын
Very nice video as always!
@khoda81
@khoda81 Жыл бұрын
Pleeeeas talk about covariance and contravariance :)
@alfeberlin
@alfeberlin Жыл бұрын
What about simply inheriting from `dict` instead of `abc.Mapping`?
@mCoding
@mCoding Жыл бұрын
For certain situations that works, particularly when your mapping type is a thin wrapper around a single actual dict, but in others it may take some "forcing" to get similar functionality. For instance, with the InvertibleDict, how would you implement inv if you inherited from dict? The inv property does not create new dicts when making the inverse InvertibleDict, it reuses the existing ones both for efficiency and so that operating on the inverse also modifies the original. However, if I inherited from dict I would necessarily be creating a new dict when I create the inverse, so instead I would probably have to create a "View" type in addition that implements the MutableMapping protocol, but that's already what InvertibleDict is.
@alfeberlin
@alfeberlin Жыл бұрын
@@mCoding I’m sorry, I should have been more elaborate: Yes, inheriting `dict` directly is often not a good solution. I meant my question more in this sense: 1) Does it make sense to inherit `dict` at all, are there any cases? 2) What problems lie in this direction? This would have made a great introduction to why the base classes exist in the first place and why inheriting them instead of the real thing is often the better choice.
@benjieeisen6819
@benjieeisen6819 Жыл бұрын
Just starting binging all your videos #pycharm
@PavelBukarev
@PavelBukarev Жыл бұрын
Maybe it's just me, but it sounded like agile methodology is something evil. As a person who worked in a dev team for a business products (yes, not the same as a video game, but hear me out), who switched from waterfall to agile, I can say that agile is not about releasing anything in two weeks no matter the quality. It's about delivering to the customers "value" in a short time, instead of making them wait longer and deliver to them something they already don't need. As a member of a team you benefit, if there is an error in the requirements you notice it faster, qa test smaller pieces of functionality instead of whole thing with a lot of subsystem and integrations at once. In this line of business, I find agile a huge help. But it's just a tool. Does this tool fit the game industry? I haven't worked in gamedev, but I think it depends. Online games for example. For sure it fits. Big single player experiences, I think it's possible, if you do it right. Don't deliver each sprint to the players, deliver it to "stakeholders" and focus groups, you'll be able to keep most of the benefits (if not all) of agile, higher-ups would always know if the project is going as planned or if there are any hiccups (being open is a part of agile), and then release it when all the parts are done. I think you can find something similar in early access indie games, but they actually release "value" then it's ready, not at the and of the project.
@aymanhassan8178
@aymanhassan8178 Жыл бұрын
you know what i really like using #pycharm
@viliamklein
@viliamklein Жыл бұрын
Thanks for the informative content! #pycharm
@Jakub1989YTb
@Jakub1989YTb Жыл бұрын
0:43 - how did you get the dark theme python docs? Looks very usable :-)
@mCoding
@mCoding Жыл бұрын
Experimental chrome flag, although as it was kindly pointed out to me, the docs for Python 3.12 allow you to select your theme, and it looks much nicer.
@siddharth-gandhi
@siddharth-gandhi Жыл бұрын
Any plans on a mojo video?
@MrWorshipMe
@MrWorshipMe Жыл бұрын
Why define a missing object variable instead of using None?
@mCoding
@mCoding Жыл бұрын
Great question! The reason is because the user may have intended to store the value None in the dictionary, e.g. {"a": None} or {None: "a"}. We need to be able to distinguish this case from the key/value not previously existing.
@MrWorshipMe
@MrWorshipMe Жыл бұрын
@@mCoding Aha, hadn't thought of that. But in that case, wouldn't it be more clear if we explicitly check if the key exists, instead of providing a default to get, and checking if we got the default?
@piot94
@piot94 Жыл бұрын
Great video as always! #pycharm
@BrianWoodruff-Jr
@BrianWoodruff-Jr Жыл бұрын
3:08 "How restrictive this becomes for the caller of the function" I have never heard of python ever enforcing type hinting. I could have "def foo(x: float): pass" and call with "foo(2.0)" or "foo([1, 2])" and get away with it. I've only ever heard of type hinting applying with LINTERS, not runtime. Sure, someone reading the library code would go, "Oh, this function is expecting a float, not a list". Sure, but like pirates of caribbean, they're more like guidelines.
@anon_y_mousse
@anon_y_mousse Жыл бұрын
The types are indeed suggestions, for now, but they may not be in the future. Generally it's a good idea, and good practice, to listen to yourself if you suggest that something may be a specific type.
@mCoding
@mCoding Жыл бұрын
You're right that it is not the python runtime that complains, it is the static analysis tools like linters, IDEs, and type checkers. In the professional world, these static analysis tools are very much a part of everyday life and depending on the project, failing a type check in CI means failing the build. Additionally, regardless of whether this is an actual blocker, type hints are a form of communication of intent between programmers. If i type hint a function as taking an int, you should not pass a str to it. If i type hint a function as taking a dict, you should not pass a dict-like thing that doesnt inherit from dict. So whether this is enforced by your CI system or not, other programmers will be affected by restrictive type hints.
@BrianWoodruff-Jr
@BrianWoodruff-Jr Жыл бұрын
@@mCoding Just be more careful about your wording in the next video. I was not saying anything about the merits of type hinting. The wording in your video made it seem like the langue enforces types: "How restrictive this becomes for the caller of the function". Maybe it was not clear as to how the caller is "restricted". Is in the human author? Is it the python run time engine? What is the "caller"? What is the "restriction"? I live in a world where everyone seems to know what everyone else means, like an inside joke or whatever. Tear me apart for why I'm responsible for misunderstanding you, but at the end of the day I still lose out. Just please, next time speak more clearly. Thank you.
@KatieKTLG
@KatieKTLG Жыл бұрын
thanks for another really good explanation! #pycharm
@mCoding
@mCoding Жыл бұрын
You are very welcome, also you get a #pycharm license! Email me to claim.
@KatieKTLG
@KatieKTLG Жыл бұрын
@@mCoding 98
@norude
@norude Жыл бұрын
Keep up🎉
@MatthewPurnell
@MatthewPurnell Жыл бұрын
Great video, as always #pycharm
@bettercalldelta
@bettercalldelta Жыл бұрын
To be honest I wouldn't mind programming content in KZbin Kids, the children deserve to get some education #pycharm
@jullien191
@jullien191 Жыл бұрын
안녕
@cesarwapler
@cesarwapler Жыл бұрын
Great video! #pycharm
@rodrigostangetessinari499
@rodrigostangetessinari499 Жыл бұрын
Thank you for the always very informative videos =) PS: Post a comment containing #pycharm to enter!
@johnneal3086
@johnneal3086 Жыл бұрын
interesting vid, thanks. #pycharm
@bereck7735
@bereck7735 Жыл бұрын
#pycharm Awesome video also always.
@plato4ek
@plato4ek Жыл бұрын
I'd like to have #pycharm
@Mayur7Garg
@Mayur7Garg Жыл бұрын
The inv property is a little expensive though. It creates a new object every time it is invoked. If the dict has too many items, the dict comprehension used in __init__ can be a little expensive. I don't have a better solution though. #pycharm
@tylerfusco7495
@tylerfusco7495 Жыл бұрын
I think that using a cached_property would work fine there
@Mayur7Garg
@Mayur7Garg Жыл бұрын
@@tylerfusco7495 maybe. But you would have to refresh the cache either time the forward or the backward dictionary is updated. The net effect depends on the ratio of reads to writes.
@coarse_snad
@coarse_snad Жыл бұрын
​@@Mayur7Garg you would not need to refresh it, it would always be up to date, as there is no way to swap the underlying dicts (within the public interface). Everything is a reference, and the dicts are not copied for the inv property. I would also argue that the overhead of creating a single python object, especially when slots are being used, is silly to worry about. Python will have larger overheads everywhere, so optimizing this part is not an effective solution.
@coarse_snad
@coarse_snad Жыл бұрын
If you really want to avoid the overhead of the extra class creation, i would add an extra field to the slots specifically for the cached inverse mapping. You would probably need to add extra complexity to __init__, but it would allow you to simply return the cached counterpart in the inv property. This would mean that for an InvertibleDict a, "a.inv.inv is a" returns True.
@Mayur7Garg
@Mayur7Garg Жыл бұрын
​@@coarse_snad Yeah.. I was actually looking at the dict comprehension call but now I realised that won't be called during inverting. During the inversion, only references need to be updated since the backward mapping is not None.
@bswck
@bswck Жыл бұрын
#pycharm my educational license ends by the 1st of june :
@anon_y_mousse
@anon_y_mousse Жыл бұрын
Have you considered using a free editor such as vim or emacs?
@HTWwpzIuqaObMt
@HTWwpzIuqaObMt Жыл бұрын
Great video
@The96th
@The96th Жыл бұрын
heck yeah #pycharm
@yihangyang1645
@yihangyang1645 Жыл бұрын
I thought abc is just a interesting name, never expected it means Abstract Base Class. LOL #pycharm
@mathiastruel1772
@mathiastruel1772 Жыл бұрын
Thanks #pycharm
@georgescugicu9202
@georgescugicu9202 Жыл бұрын
something something #pycharm
@PickleBryne
@PickleBryne Жыл бұрын
Gimme #pycharm
@Micaeljm
@Micaeljm Жыл бұрын
#pycharm
@jullien191
@jullien191 Жыл бұрын
Thích nhỉ.
@shahnawazazam
@shahnawazazam Жыл бұрын
early gang
@motbus3
@motbus3 Жыл бұрын
Great joke on 15 series video
@bringbestoutofbest349
@bringbestoutofbest349 8 ай бұрын
What is he teaching in this video?
@arbybc7188
@arbybc7188 Жыл бұрын
fn = InvertableDict({ 0: “Tokenizer”, 1 : “ #pycharm “})
@tusharkuntawar6170
@tusharkuntawar6170 Жыл бұрын
## #pycharm #neovim #novs*code
@capivaracafeinada
@capivaracafeinada Жыл бұрын
Great video as always! #pycharm
Metaclasses in Python
15:45
mCoding
Рет қаралды 158 М.
Caleb Pressley Shows TSA How It’s Done
0:28
Barstool Sports
Рет қаралды 60 МЛН
ССЫЛКА НА ИГРУ В КОММЕНТАХ #shorts
0:36
Паша Осадчий
Рет қаралды 8 МЛН
Война Семей - ВСЕ СЕРИИ, 1 сезон (серии 1-20)
7:40:31
Семейные Сериалы
Рет қаралды 1,6 МЛН
21 MORE nooby Python habits
9:55
mCoding
Рет қаралды 122 М.
Protocols vs ABCs in Python - When to Use Which One?
15:31
ArjanCodes
Рет қаралды 44 М.
super/MRO, Python's most misunderstood feature.
21:07
mCoding
Рет қаралды 222 М.
Async for loops in Python
16:36
mCoding
Рет қаралды 68 М.
Protocol Or ABC In Python - When to Use Which One?
23:45
ArjanCodes
Рет қаралды 206 М.
Every Python dev falls for this (name mangling)
14:11
mCoding
Рет қаралды 140 М.
__new__ vs __init__ in Python
10:50
mCoding
Рет қаралды 210 М.
Avoid These BAD Practices in Python OOP
24:42
ArjanCodes
Рет қаралды 82 М.
Python itertools - The key to mastering iteration
20:03
mCoding
Рет қаралды 36 М.
Intro to async Python | Writing a Web Crawler
14:23
mCoding
Рет қаралды 82 М.