👷 Join the FREE Code Diagnosis Workshop to help you review code more effectively using my 3-Factor Diagnosis Framework: www.arjancodes.com/diagnosis
@Ziggity2 жыл бұрын
If only I had this when I first started out. The amount of useful information you were able to so succinctly squeeze into a 25 minute video while keeping things clear and accessible is outstanding. Fantastic Job.
@Acuzzio2 жыл бұрын
Agree
@BenKraal Жыл бұрын
Agree x2
@hovikkevork3069 Жыл бұрын
Crazy value in less than 30 mins! Not only you know what you're talking about, you also know how to deliver it in simple terms. Thanks.
@ArjanCodes Жыл бұрын
I appreciate that!
@hcubill2 жыл бұрын
I have followed you for a couple of years and this is my favourite video. You are getting so clear and concrete with your points. Functions did deserve a video like this!
@ArjanCodes2 жыл бұрын
Thanks so much Hector - glad you liked the video!
@shashankbang102 жыл бұрын
Hello Arjan. I have been following your tips for a while now. It’s completely changed the way I write code and I have received accolades at my work for the significant improvement in code style. I want to thank you very much for it. Please make more videos like these.
@tugrulpinar162 жыл бұрын
Same here, thank you Arjan!
@nitzan39842 жыл бұрын
Same
@gwho Жыл бұрын
Another tip: put your 17:00 Put PaymentHandler and StripPaymentHandler, related subclasses/polymorphisms next to each other. PRICES is particular constants (which are akin to arguments) as opposed to PaymenteHandler and StripePaymentHandler class definitions (which are akin to function definitions). So in sum, separate arguments from parameters, or templates from values.
@StavrosSachtouris2 жыл бұрын
Guido Van Rossum initially named his language "stroopwafel", but it didn't take off because the name is too long. While he was visiting a zoo and thinking ideas for a shorter name, a snake ate his stroopwafel. Guess what type of snake it was. (I cannot give you any hints, because stroopwafel didn't support type hints).
@PavelSTL2 жыл бұрын
Umm Cobra?
@AnotherAvaibleName2 жыл бұрын
was it a coralillo ?
@victor_silva61422 жыл бұрын
An Oroshimaru?
@moustachescarz2 жыл бұрын
a pythong?
@ravimaithreyregulagedda21582 жыл бұрын
this is a nice story but I hope you aren't implying that's how he named the language because python is named after Monty Python not the snake python
@mohammednasser2159 Жыл бұрын
You could've added the cc_validation function as a method for the Card class, and even turn it into property, or validate it upon instantiation in the init, will make even more sense. Great content, keep going ❤️
@qwerty111111222 жыл бұрын
Glad you mentioned there should be a verb in a function name. def verb(direct_object, indirect_object, ...): ... Or for methods, subject.verb(objects). Been trying my best to be consistent with using normal grammar to make my code make sense, like using plurals for collections to make loop variables easy to name.
@Personal-M.I.S. Жыл бұрын
Just to say, I've only dabbled in Python and don't know much more than the fundamentals of the language, but I still get A LOT out of watching your videos. I really appreciate how your presentations are so chill and straight to the point. Even when I can't quite tell what's going on with the language, I can get the idea you're trying to teach. Good stuff!
@marcioneto30162 жыл бұрын
After tulips and cheese, I really thought you were going for windmills, but nope 😂. Great video, as always!
@kaincenteno36094 ай бұрын
lol i was thinking the same, then BAM! that third one made me giggle 😆
@heitortremor2 жыл бұрын
I'm excited for this one! I've always wondered if I was going about functions in the most efficient/optimal way and I'm sure these tips will guide me to be better.
@angelcaru2 жыл бұрын
Summary of this video: == TIPS == - Functions should do one thing, and one thing only - Side effects (commands) or computations (queries), not both - Request only what you need - Minimal parameters - Separate creation and usage - No flag parameters (split up functions instead) - Use higher-order functions == NAMING == - Split up functions with `and` in their name - Shorten - Names should be verbs, arguments should be nouns - Always use the same vocabulary - Use the languages preferred_naming_scheme and notTheWrongOne (so never touch C#) - No spelling or grammar mistakes (duh)
@Kev13052 жыл бұрын
You forgot one key bit - Python should be called Prostitute.
@myce-liam2 жыл бұрын
You've forgotten one of the most important take-aways: Arjan thinks Python should have been called Prostitute. "Prostitute 3.11 is up to 60% faster than Prostitute 3.10"😄
@kayakMike1000 Жыл бұрын
And? The function should do one thing only...
@paultapping9510 Жыл бұрын
@kayakMike1000 a redundant and somewhat idiomatic but nonetheless correct formulation.
@Personal-M.I.S. Жыл бұрын
Nice! You've taken some of the most fundamental clean code practices and distilled them down to a very coherent and concise 25 minutes with no hand waving or fluff. Uncle Bob would be proud =)
@hukl39452 жыл бұрын
Bonus Tip: Don't nest conditionals. While two simple, nested conditionals might be acceptable but I would already try and think of a better way. When you have three levels in your decision tree it might be time for a truth table. It may seem cumbersome to adhere to this rule but in my experience it always leads to better structure in the code.
@EricT432 жыл бұрын
Hi ArjanCodes, thanks for the video! I appreciate the way that you teach these coding concepts - you strike just the right balance, in my opinion, between conceptual and practical explanations.
@NoobomgWhy2 жыл бұрын
My favourite Dutch things so far: Frikandeln, Vla and Pasta Choca. Now I can add Python. Thank you!
@katja_und_mickey Жыл бұрын
Another great watch! I am so glad there are so many great videos on your channel! Thank you so much for all the valuable information.
@ArjanCodes Жыл бұрын
I'm glad you're enjoying the content!
@ARandomOWL2 жыл бұрын
Python should have been called Stroopwafel.
@lachlanstanding73862 жыл бұрын
That's a funny name, I'd've called 'em Shaswazzas!
@thunder____2 жыл бұрын
@@lachlanstanding7386 I see you've played "knifey spoony" before
@zyklos2292 жыл бұрын
how in the hell, you have so much tasty food in netherlands :D
@Einimas2 жыл бұрын
It's a windmill.
@leaoaugusto Жыл бұрын
why?
@_baco2 жыл бұрын
Really gooood video!!!! To @GrammarNazi, at work we happen to have a Django model named “Custom”. Because classes should be singular names in Python... and someone thought Customs was a plural 🤦♂. We still can not safely refactor that.
@ElNachoMacho2 жыл бұрын
Great video as always. I always learn something new watching your content! Thank you for sharing
@JZ1917 Жыл бұрын
The humor quality is increasing with each video. Not only did I learn, I chuckled a few times !
@ArjanCodes Жыл бұрын
Glad you like them!
@JesusMRamosPerez Жыл бұрын
Thanks a lot for these videos! Can't stop watching them!
@madao4024 Жыл бұрын
that was a good one at 5:50 🤣
@SuperDoc30002 жыл бұрын
This man's content is a gift, thank you Arjan
@lekhakaananta58642 жыл бұрын
5:48 "There are no Pythons in the netherlands...should have called it Tulip, Cheese, or Prostitutes" Totally, imagine the job ads. "This position requires 5 years of experience in Prostitutes"
@yahyakhan-rr9ei2 жыл бұрын
One of the best channels, and for free. Feels amazing.
@danielkonstantinovsky108 Жыл бұрын
It's very interesting for me to step into the mainstream Python developer world on KZbin. I'm a scientist and I write tons of "complicated" Python (and Cython and C++) code but the complexity is very different in scientific code - it's in the math and the algorithms rather than the stack of code that manages other code as seems to be common in mainstream codebases. We use abstractions like classes of course but our hierarchy of abstractions is much less branched than here, more like a stack than a web. We like our input files with dozens of parameters (🙂), which flows into some main, which calls some objects and functions, that kind of thing. This comment in itself is not a criticism of common design patterns - I don't feel qualified to criticize them, but I do note how difficult it is often to find the code that actually _does_ something in "professional" codebases. There is so much fluff that is supposed to manage the complexity that it becomes quite complex in itself. That has always frustrated me. Good abstractions are hard to come by, and mainstream code is full of bad abstractions for the sake of abstraction. Sometimes it's better just to _do_ the thing you want to do, rather than erect an entire class of middle managers, usually classes, with abstract-sounding names. If your core algorithm is ten lines or so (as is amazingly often the case by the way), there is no justification for writing 5000 lines across 14 source files to "manage the complexity", but that's often what you see. Bottom line is when you manage complexity you introduce complexity, and that has to be controlled if you're going to make the code friendlier to the developer and user. As you may have guessed, I'm a big fan of Brian Will's diatribe on OOP, not that I think classes are bad (he doesn't either) but that I think most abstractions are bad, and cementing them in with further bad abstraction is a bad idea. Just some thoughts from a scientific programmer - I live in a very different world from all of you, but maybe I have some useful insights because of that. I don't know. You decide.
@danilkister16502 жыл бұрын
This video is heavily underrated!
@gshan9942 жыл бұрын
Quicktip: you can select cc and then hit ctrl/cmd + d to select next occurance of cc. With this u can change selected same words.
@weistrass11 ай бұрын
Didn't know those partial functions!!! Sooooo gooooood
@ArjanCodes11 ай бұрын
I'm glad you learned something new!
@wizardfix Жыл бұрын
Nice. Very good advice about separation of concerns. Thank you.
@ArjanCodes Жыл бұрын
Glad it was helpful!
@danny_p4662 жыл бұрын
It's great to see Uncle Bob's Clean Code lessons apply still to this day! Thanks for the video :)
@uwegenosdude11 ай бұрын
Thanks for the great video.Especially I liked the trick to force keyword arguments. And the closed open principle.
@ArjanCodes11 ай бұрын
Glad you enjoyed it!
@drhilm2 жыл бұрын
Love this kind of videos. Thanks. This is something to return to...
@ArjanCodes2 жыл бұрын
Thanks so much Dror, glad the content is helpful!
@mikelancaster8924 Жыл бұрын
These videos are very necessary, thanks!
@ArjanCodes Жыл бұрын
Glad you like them!
@Krazness2 жыл бұрын
Great video. Have you considered creating a video covering partial applications for functions?
@ArjanCodes2 жыл бұрын
Great suggestion Richard, thank you!
@innstikk Жыл бұрын
Excellent video! There is one thing that I didn't understand. In order to not pass all the user information you made a CardInfo protocol and said that it then would only pass on the information in the protocol. I tested this, but I can still access name from the User dataclass in this way. So the protocol doesn't extract only the variables it contains, but I guess only checks that those needed are there? So in effect you send over as much data in this way as with simply passing the User without the protocol. The protocol approach is nicer than sending the User, but having a Card class is even better.
@abymathew5752 жыл бұрын
wow I really like this video. What a clarity and clear explanation with real examples. Thanks for this wonderful video. 👏👏👏👏👏👏
@ArjanCodes2 жыл бұрын
Thanks so much Aby, glad the content is helpful!
@gshan9942 жыл бұрын
Ur explanation is very clear n concise. I learned something new today. Thanks
@ArjanCodes2 жыл бұрын
Thanks so much GShan, glad the content is helpful!
@JackQuarm2 жыл бұрын
Your channel is brilliant, keep up the great vids!
@ArjanCodes2 жыл бұрын
Thanks a ton!
@fmictsang88742 жыл бұрын
In 13:50 you mentioned multiply cards for one person. I would like to ask how should it be store in the Customer object? Would it be like alice.card = [card1, card2] ?
@NostraDavid22 жыл бұрын
Yeah, that would be a decent solution. You'd need to add a few loops here and there, but yeah.
@InvestLarge Жыл бұрын
New to the channel since yesterday's KZbin recommended your video on Classes. Subscribed and liking the tutorials. I am learning and also seeing new things that I don't know what they are for. Decorators perhaps? protocol, hmm Going to look it all up and become better knowledged
@ArjanCodes Жыл бұрын
Thank you so much!
@skellious Жыл бұрын
I learnt so much from this one video
@Kamil-so1se2 жыл бұрын
Great as always.
@CodingIsFun2 жыл бұрын
*Very helpful, Arjan! Thank you!* 👍
@ArjanCodes2 жыл бұрын
Thanks so much, glad the content is helpful!
@georgH Жыл бұрын
Eiffel was used in some classes back in the day at my uni, it really helped me on understanding OO, it was so much nicer than Java (which didn't even have generics back then). Bertrand Meyer named an engineer's language on a great French engineer: Gustave Eiffel. By this rule, Python might have been called "Tideman" or "Lely"
@aashayamballi2 жыл бұрын
Thanks for the great video again Arjan! It was really informative and helpful🙏
@Mike-vj8do Жыл бұрын
Enjoyed the video!
@ArjanCodes Жыл бұрын
Glad to hear it!
@mohammadsharara3170 Жыл бұрын
Very juicy video, and at the same time funny, especially the joke about PyQt 😂. Thanks!
@ArjanCodes Жыл бұрын
I'm happy you enjoyed the video!
@nickeldan2 жыл бұрын
The sound of your keyboard is so soothing.
@Viertelhund2 жыл бұрын
13:45 I wished you'd have moved the validate_card method into the Card class as validate method without a parameter.
@ivannuzhyn46682 жыл бұрын
Awsome video, a lot of very usefull info for me. Thanks a lot!
@ArjanCodes2 жыл бұрын
Thanks so much Ivan, glad the content is helpful!
@EAenergy Жыл бұрын
The Dutch guy said order salad instead of fries Holly crap haha. The first time I visited Holland my culture shock was how much fries is consumed. I did not connect the Irish historical famine with the current reality. Love your style and had a blast in Amsterdam. Keep up the good work and thank you for putting these together!
@maortizm992 жыл бұрын
What's the advantage of using partials over lambdas? Is it just about readability?
@Vijay-Yarramsetty2 жыл бұрын
thanks a lot. great content
@evgenyocean4262 жыл бұрын
Serious question: How can you stick to the default vscode theme for so long? It doesn't not even highlight function arguments in the function body. Is it for video recording only or you do actually use it on a daily basis? BTW. Love your content. Thank you!
@ErikS-2 жыл бұрын
5:45 - 😂 Arjan is spot on here!
@philscosta2 жыл бұрын
Great video as always! I also love partial functions in Python. One issue I have with them though, is that the type checker in Pycharm doesn't really know what to do with them. For e.g. def sum(a: int, b: int) -> int: .... sum_2 = partial(sum, b=2) The type checker shows and error when it checks whether sum_2 is of type Callable[[int], int]. Does anybody else have this issue? What do you all do about it?
@NostraDavid22 жыл бұрын
What error does it show?
@CoilYsum2 жыл бұрын
Why do you use validate_card(card) and not validate_card(alice.card) in tip 4 (at around 14:00)?
@wiktormorela4907 Жыл бұрын
Hey Arjan / youtube community. every time i watch those videos, i have a feeling that applying this knowledge into my data engineering python tools would be an overkill. Can you recommend something like levels of complexity in python code, where one could judge design quality of code based on those levels? As an example, how long one should stay in single module project, what is the moment when design should consider dataclasses etc.
@Nellak20112 жыл бұрын
So on the first example, the luhn checksum one, it is ok to leave the functions all inline IF AND ONLY IF you know that the requirements wont change and you will just use it in that one place. Other than that it is a bad practice as it leads to less code coherence and more coupling, which makes thing hard to change. The few advantages to inline are efficiency and faster to write, but in a large software in prod, the drawbacks outweight the trivial advantages. In general, nearly always extract out to make your code more modular and easier to read, it is just common sense.
@zknarc2 жыл бұрын
For data related code, how do you deal with passing dataframes to functions? Should you select only the colums which are needed or pass the whole thing?
@NostraDavid22 жыл бұрын
I would pass the whole thing, as objects are passed by reference instead of pass by value. If you only pass the bits you need, you're likely to copy a bunch of data unnecessary.
@doctor69322 жыл бұрын
loved this
@ArjanCodes2 жыл бұрын
Thanks so much, glad you liked it!
@tesszheng45867 ай бұрын
at minute 5, for this piece of code: for digit in even_digits: checksum += sum(digits_of(str(digit * 2))) , I feel like we could write: checksum += sum(even_digits) * 2, thus we don't need to enumerate each even_digit, times 2 , convert to string ten convert back to an int list, then sum up.
@DS-tj2tu2 жыл бұрын
Thank you!
@ArjanCodes2 жыл бұрын
Thanks so much, glad you liked it!
@irenaronen7497 Жыл бұрын
Thank for the video! I also seek how to use functions within the dataframes, namely in Polars, and how to incorporate it in DuckDB (using SQL in Polars dataframes). Working with alot of data is a bit frustrating, and I seek ways to use real-case data analyses. Also wonder how to use the Python Class system in the above case... Don't want to overload the system with too many variables.
@whkoh76192 жыл бұрын
Amazing content as always. Thank you Arjan
@ArjanCodes2 жыл бұрын
Thanks so much, glad the content is helpful!
@ervankurniawan9267 Жыл бұрын
The only thing I just want to say is, since I found your channel and has watched some videos, I never look Python is easy anymore. And every time I look at my current Python code, it's looks like a dumb code. 😂 Thanks for the content. 👏🏻
@David-1242 жыл бұрын
Great video! At 23:14 and 23:29 did you mean to say "Parameter" rather than "Argument"? 😱
@aperturesignaturebandwidth Жыл бұрын
@12:05 you seem to indicate we're running validate_card on the CardInfo type but you pass the Customer?
@mr.wheelers55042 жыл бұрын
Hi Arjan! Great video as always, I feel like I've learned more about python programming from you than I have during my astronomy studies. At 16:45 in the video you create a PaymentHandler baseclass using a Protocal. Howcome you don't use an AbstractBaseClass for this? Using a protocal like this seems to ignore the "better explicit than implicit" principle. Is there some advantage to using a protocal like this?
@gedtoon6451 Жыл бұрын
At 13:04 you created a "Card" class. If you have a class representing a credit card, would it not be sensible to have a "validate_card" method inside it?
@leniedor7332 жыл бұрын
1. SRP from the S of SOLID + some good refactor examples
@mithunmanoharmithun2 жыл бұрын
Awesome content. Keep going !
@ArjanCodes2 жыл бұрын
Thanks so much Mithun, glad the content is helpful!
@paxdriver Жыл бұрын
I just realized Arjan has 10% the subcribers I just assumed the channel had from watching for so long. I honestly believed for years this was a 1 million+ channel and only just now realized it wasn't. I need to comment and share more, this is my fault.
@ArjanCodes Жыл бұрын
Thank you so much for your support Kristopher!
@Gukzilla2 жыл бұрын
As a self taught, these design principles are really that one thing that I felt is missing to pull of brilliant code.
@ArjanCodes2 жыл бұрын
Thanks so much Gukzilla, glad the content is helpful!
@luck39492 жыл бұрын
Flags argument seen to be stretched: N flags represent 2^N functions. Flags might be written in configuration file, so using them in some form or another might be necessary. Splitting one function into many just to remove flag might lead to code repetition.
@tolstoievski4926 Жыл бұрын
Is the protocol class cardinfo still relevant after creating a separate data class for the card ?
@confuso12 жыл бұрын
Very good video, thanks a lot, instant abo
@ArjanCodes2 жыл бұрын
Glad you liked it!
@teddy930285 Жыл бұрын
I like how you grumbled random stuffs like the paypal and naming of Python. That just makes the video so much entertaining and fun to watch, while still being extremely informative. Thank you!
@tadastadux Жыл бұрын
Thank you Arjan. I'm just wondering if you swapped ABC with Protocal libraries.
@kristianhig32832 жыл бұрын
thanks it worked
@ArjanCodes2 жыл бұрын
Thanks so much Kristian, glad the content is helpful!
@CFox.7 Жыл бұрын
The mind of the coder - they think they are creative but they are not they are just master organisers ! and no you dont need to be creative to be organised - its just a matter of finding the optimum for the goal ( within constraints of course ). Choose your focus.
@nfredrik2 жыл бұрын
what is the diff btw 'def validate_card(card: CardInfo)' and writing 'def validate_card(card: Card)' Is it syntactic sugar? It do not to scope down number of props passed the validate_card() when executing, property 'valid' still there.
@marcelgrolain27642 жыл бұрын
Thanks for the inspiration
@MagnusAnand2 жыл бұрын
Arjan, I have one question not related to this video: working with an ORM (like Django's), how do you use the SOLID principles? If you ever talk about this it would be so cool 😜
@mikefochtman71642 жыл бұрын
One thought that popped up as I watched, couldn't we move the date checking into its own function? I know the date checking is pretty trivial, one line and all, but "do one thing, and do it well". So 'validate-card' would simply be " return validate_number and validate_date;" If later we wanted to do something more, such as 'validate-ccv' that too could be added in a similar manner. Having a separate date validation would help compartmentalize things such that some future changes to 'date checking' are localized to one function. For example, most CC here in the US are valid through the END of the month and don't expire on the first. Looks there like your CC is not valid on the first day of the exp_month?? How many places in all the code have to be searched to fix such a bug if you do date-checking in-line everywhere??
@AnotherAvaibleName2 жыл бұрын
thanks Arjan, very nice and based
@ArjanCodes2 жыл бұрын
Thanks so much, glad the content is helpful!
@mikeciul8599 Жыл бұрын
In other videos, I recall you've advised against including types in variable names. Maybe it doesn't apply here because it's a type variable, but when you called the type HandlePaymentFn I wondered about the naming scheme. When I name function types, I usually put "er" at the end of the name. In this case the function type would have the same name as the class it replaced, "PaymentHandler." I probably would have called the param "handle_payment" rather than "payment_handler" though. e.g.: PaymentHandler = Callable[[int], None] def order_food(items: List[str], handle_payment: PaymentHandler) -> None: ... What are your thoughts? How does everyone here name their Callable type variables?
@lunkums2 жыл бұрын
7:48 not a big fan of this tip because of the data clumps code smell. In general, if you're passing in a few members of a class, you really should be passing the whole class because it's clearer than passing individual arguments. It's not immediately apparent to someone reading the code how those arguments are related, unless they're named similarly, and if you end up needing more data members from the Customer class, you need to update the method signature. Also, if you're performing an operation using a customers data, if you pass in the customer then you're ensuring that the operation will only use the customers data
@pitter66362 жыл бұрын
How would you proceed in creating functions for dataframes?
@kovlabs Жыл бұрын
Could you do a deep dive on building your own modules Please 🙏
@ArjanCodes Жыл бұрын
Noted!
@MrHarleking Жыл бұрын
Hi, i love your Videos, but please use a zoom on you screen when u show and work with Code. Thx a lot for your work!
@pointer3332 жыл бұрын
I don't understand the card info protocol... Was that left as an incomplete example, or is the class declared completely, for use as a protocol?
@walis853002 жыл бұрын
Thanks for the video. One question: in the protocol class, is it required to mark as properties the class’ attributes or it can be declared as attributes?
@Shivnaren2 жыл бұрын
Marking the attributes as properties is the only way to declare them as immutable (useful for NamedTuple instances, or just a `const` like declaration); but they can be declared as attributes too.
@mikeciul8599 Жыл бұрын
What is the name of the code smell where an object is created and used in the same place?
@cgi_arb2 жыл бұрын
What is the benefit of creating the "digits_of" internal function within "luhn_checksum"? Why not just digits = [int(d) for d in card_number]?
@grzegorzryznar51012 жыл бұрын
The biggest problem with the partial is the fact, that none of the IDE or even mypy cannot support it. So function created via that is totally ambigous without using something like Protocol to annotate return value. Another problem with funcional protocols is the fact, that you are missing annotation if you annoate it with Callable. Better to use Protocol in more advanced scenarios with annotated __call__.
@ran_red2 жыл бұрын
But couldn't you just annotate it as functools.partial? like only_partials: functools.partial Pyright complains if I do that and assign it a Literal, as an example. Sorry if I am not understanding your message and suggested something stupid btw
@MagnusAnand2 жыл бұрын
One question not related to this video: How to solve the relational impedance mismatch? If I use the solid principles to design a payment system (like you did in a different video), an employee object, contrast object, commission object. You use interfaces, composition and inheritance. But how to reconcile this with the database??? I’m quite confused. Thanks.