Agreed. While I really enjoy James Powell videos like the one below, @ArjanCodes just presents things in a very fluid manner. ua-cam.com/video/cKPlPJyQrt4/v-deo.html My colleagues were lost with the content presented in that James Powell video. But I hope that no one was lost with what @ArjanCodes presented in this one. Good job @ArjanCodes! Thank you.
I've consumed a lot of programming content recently and this channel is one of the best I've seen. Well produced, professional and perfect pacing. Even the occasional joke!
Great stuff. I have never understood decorators... Until now. It was so nice how you showed step by step how it works. I thought decorators were only python thing but now I see its a general concept doable in all languages
This is just gold on youtube. So many junior devs don't understand decorators in Python, and think of them only as this "Magic" that you put on top without understanding anything. Thank you, Arjan.
Hi, Arjan! Can you make a video about "module/package structure" in Python? For instance, using a project as an example, what classes should be grouped together in which modules/packages (nomenclature, subjects, etc). Regards!
Yes x1000. While the syntax isn’t too hard to get my head around, best practices is always difficult to get a handle on. And most info on web is for open source projects. It’s actually quite difficult to get an idea of how to robustly share internal packages with the rest of your team in a non-open way.
I came for the high quality and well thought out content. I stayed for it too. But I loved it for all of the glorious puns. :D Thank you for the education and the puns. Both are much appreciated!
My python code always looks like it's straight out of the 90s and yours reminds me of something from another time completely. Definitely should brush up more :)
It's literally like you're spying on my current challenges at work! There's a heavily nested decorators function that is being used and this has cleared things up a lot! Thanks so much, keep going with the great work!
I know the decorator pattern from top of my head, but I use python decorators so rarely I have to re-learn them every time :) Another good use case for decorators is error handling. We catch different exceptions in a web app on different layers and turn them into http errors. But overall decorators are a niche thing.
Welp. I guess I now know exactly what I need to rewrite part of a work project. There's some complicated and annoying interdependencies that I am not a fan of, but I hadn't figured out how to solve it. Also, thanks for explaining something that as far as I could tell were just magic!
Excellent presentation! I think I need to watch this two or three times to fully understand as this is a lot like the movie Inception, dreams within dreams… Thanks for putting the time into this content and also for the additional discussion at the end where you discussed practical use. Cheers!
I definitely agree that wrapping logic in decorators makes code harder to read, but I love using them to register handlers, like how Flask defines routes. I use it like that all the time for event handlers, and I just think it makes the code super easy to read and understand. Love your videos, so happy to see someone else who loves Python as much as I do 😁
BTW, flask's decorator functions also return the original function unchanged. So even though a function is a flask route, you can call it just like a regular function if needed. Flask's types were broken regarding this fact, and I had to fix them sometime last year.
You asked if anyone was using their own decorators, so here goes. We're developing a Flask application with authentication, of course. We are using the Flask-provided login_required decorator but also require different roles for the users. This meant testing whether the user had the appropriate role at the beginning of certain routes. I decided this was essentially code duplication and really required a new decorator in which you supply a list of roles. Surprisingly easy to write, really. It's part of the code base and documented, so a future developer of the application should understand how and when to use it.
JIC: we also can implement decorators using class with `__init__` and `__call__` method (`__init__` for parameterizing and `__call__` for applying deco to func of class) And in addition we can decorate not only functions but classes as well
Great video. For anyone wanting to use the with_default_logging decorator, be aware of a potential issue. Most likely, the logger object will have the name from the module where it was instantiated. If you import it via decorator into another module, it might get confusing where the logging call actually came from because the logger name can be mistaken for the module name. I definitely had the issue in the past and it took me a while to figure out what was going on.
I have watched a few videos on this topic and you explained the best. It's so easy to understand with some background (classic decorator pattern in OOP and then how Python gets it done). Thank you.
Decorators are truly a double edged sword. I have used them in the past to pass on a database session through multiple layers of controllers in a rest application. The decorator took ownership of the session and decided when to open / flush / commit / and close the session. It also added some parameters to every controller function in order to implement some security features. It worked wonders for our project as even after countless controller calls a session could seamlessly revert to an old state if an error occurred and controller functions were automatically secured, but to this day it confuses some developers when working with it, because not everyone understands python decorators well. Though I still stand to that design choice today.
This is the one of the most interesting and enlightening video within your playlist. I am about to flex all these skills from your video into my code-base. 🤣
I started watching recently and I have been pleasantly surprised by the quality of your content. There is one caveat, I think, to using the @decorator syntax of python and that is if you need to provide different parameters to the wraper function in different moments. Since the decorator is set at the beginning of the definition of a function, you would either define a function multiple times with the decorator with updated parameters, or use one of the other ways to use a decorator as you showed in the video.
Realized now that Arjan codes is one of the only channels that when you ask for a like i actually stop and like the video. Thought goes like: "that's so useful, it really deserves a like" hehe btw: i would like to see your deep dive on the import system ...
I was trying to accomplish a decorator in a class and couldn't make any sense of it until i saw this video. Arjan explains the best and most generic way of achieving a decorator.
Really nice video! I discovered Decorators in my new job (C++), but we use the traditional pattern because we can change the order and list of them by the DI configuration tool or inside factories. Amazing how things like anticipation, sync or cached operations are decoupled from the model object.
In my previous work, VW group, decorators were used to decorate classes and decorators created instances of classes that we wanted to use in the class. So they were some kind of Factories for other classes. I had no idea how that worked at the time :)
Great video, I use decorators all the time, but only the cases as you show in the video benchmarking and logging start of end of a method call. Never use multiple decorators, if i need both timing and logging, i create a single decorator that does both
One of the best python video makers ever.. Keep going sir.. 😁 I have been following since so long, I'm a machine learning engineer and I come here once in a while, and always watch the latest ones to be sure my python skills are state of the art 😎
For me the option that makes most sense is to use functions in the decorator design pattern. That way, if you're benchmarking code (say, in a jupyter environment) you can called the decorated functions of methods, but when you're deploying the code in a script that needs to run for hours and no one will look at, you can call the function without the decorator, thus leaving out a bunch of logging and calls to perf_time()
I wrote a decorator for a web application once that enforced authorization. It would get the user session object from the coroutine context and verify that the user possessed the permissions defined in the decorator call. e.g. @secure('write_permission') Great videos btw! I would appreciate a video on decorator classes. I've always found them very hard to understand how they work and what the pros/cons are. Oh, and a video on the coroutine context! Thanks!
Thank you so much for the videos! Could you use more visuals (drawings) before writing the code? I guess if you draw what you are trying to build before building it, this will deliver the message perfectly
One notable case where I built my own decorators was to build a mini-ETL framework. I was using decorators to inject data validation checks pre and post transformation steps. Also reused the @nested_dataclass trick someone posted online to be able to create dataclasses with nested dataclasses members off of unpacked dictionaries.
The most useful tip with decorators especially in-case where a decorator handles input, for example in authentication the best possible way to handle invalid input is to raise an Error : raise UnAuthenticatedError(message) then handle the error else where on your code, any other means of handling invalid arguments or invalid credentials is bound to cause problems with Flow.
for example if you handle invalid arguments by passing along a variable or credentials , then if they are invalid and you forget to handle the case where the credentials where invalid in the method or function in which the decorator is being used, you may not find this bug... straight away,
One more fantastic python guide. ❤️ You make it easy to learn. Are you also going to tackle another programming language, like javascript? Or will that hurt your UA-cam algorithm too much?
I expect mixing programming languages will hurt the channel. But I might start another channel in the future that focuses on a different programming language.
Great video as always, I use the built in decorators but Ive never reach the point of making my own. It looks awesome but in practice I feel its a bit convoluted as an end user. I will definitely will try them out now. Thank you for the great video.
I recently implemented a version elevator system using decorators. The version elevators were just simple functions that take in a config object and modify it in-place updating it to the next highest version. The decorators were needed because some versions needed multiple mending functions due to inconsistend versioning plus we also had some functions that were just there to provide some convenience options in the configs. As such, the decorator would take the version for which the mending function should be applied as an argument or None it is a convenience thing. The decorator would then take care of adding logging and registering the mending function. Now, outdated configs can be updated by just running all the version escalators on it in the given order, e.g. if the config is version 3 and the current version is 5 it would be 3->4->5 and then run all of the convenience stuff. I think the decorators make the code quite tidy since all you see is really only the migration logic. I would recommend using the class-based approach with `__call__` when you want decorators that take arguments though. I find them easier to read than three nested functions and it makes dealing with defaults easier as well.
Thank you so much for your hard work and the effort you put into your channel. Great video!!! Quick question/ idea for another video Could you describe the difference between Decorator and Proxy Design patterns? Thanks in advance!
I use decorators mostly for testing and debugging. Having a dedicated decorators for benchmark and logging produces less clutter and I can simply remove the decorator if I no longer need it. I also use my own @NOT_IMPLEMENTED decorator to automatically raise a NotImplemented exception and print message to the console, so I don't have to write the code manually in every function over and over. Otherwise I try to stay away from decorators (unless it's property, dataclass or pytest fixture).
I really like functional programming and specially haskell. I often try to see how to reproduce haskell behavior in python for fun (and sometimes profit). Decorators were the obvious choice to implement currying. The not so obvious choice used by functools.partial (class) is much better, but requires more work to work properly.
Decorators are a wonderful way to challenge people to explore the more abstract tools in Python and their also wonderful for making DRY-er code. I recently used decorators to support a test structure, where the decorator would display information, e.g. pass/fail the return of all the test, given the test methods only returned bools.
I usually use the decorators from packages, I didn't had the need to create stuff for myself.. but watching this video, I see there is a lot of small stuff I do a lot in my code that could be an decorator.. just low level stuff like error handling and logging..
I was hoping that you would talk about ParamSpec near the end to be able to preserve the argument types of decorated functions for better autocomplete :)
This is extremely interesting, I am working on a Flask 2.0 project and would like to know if you have any videos on Flask. Search did not find anything apart from GarphQL VS Rest. Thank you.
Great Video Arjan. How would you implement an async decorator for async functions or a decorator that can be used on both sync and async. Still found a solution that "feels" right
Hi Arjan. Your code examples from git have small mistake. When you check for prime number you forget to convert stop elm to integer => for element in range(2, sqrt(number) + 1). sqrt return float thats lead to TypeError Exception
I notice you only talked about function decorators, not class decorators. They have their uses, too. I think the most extensive use I have made of custom decorators so far has been in my DBussy package, a pure-Python wrapper for libdbus. The information defining the D-Bus interface to a Python class is specified via a function decorator on each Python method implementing a D-Bus interface method, with a class decorator to tie it all together. Then when you register your class to receive messages, the dispatch mechanism knows how to decode incoming D-Bus method calls, convert the arguments and dispatch to the appropriate Python method. As a bonus, this same information is used to automatically generate the D-Bus XML introspection format, when another D-Bus peer sends you the introspection message. And conversely, when you introspect another D-Bus peer, this info is used to dynamically generate a “proxy interface class” -- a Python class whose methods simply send the appropriate D-Bus messages and return the responses.
The way you progressively take the viewer through the level of abstraction is one of the best parts of this, and many of your videos.
Yep, exactly!
Agreed. While I really enjoy James Powell videos like the one below, @ArjanCodes just presents things in a very fluid manner.
ua-cam.com/video/cKPlPJyQrt4/v-deo.html
My colleagues were lost with the content presented in that James Powell video. But I hope that no one was lost with what @ArjanCodes presented in this one.
Good job @ArjanCodes! Thank you.
I've consumed a lot of programming content recently and this channel is one of the best I've seen. Well produced, professional and perfect pacing. Even the occasional joke!
Thanks so much!
".. a pain in the class.." 🤣 Added to my sayings... Thanks Arjan!
Great stuff. I have never understood decorators... Until now. It was so nice how you showed step by step how it works. I thought decorators were only python thing but now I see its a general concept doable in all languages
Glad you liked it!!
"@ArjanCodes"
It even works on UA-cam. I'm just trying to wrap Arjan's Glad-you-liked-it to decorate my comment.
This is just gold on youtube. So many junior devs don't understand decorators in Python, and think of them only as this "Magic" that you put on top without understanding anything. Thank you, Arjan.
Thank you!
Hi, Arjan! Can you make a video about "module/package structure" in Python? For instance, using a project as an example, what classes should be grouped together in which modules/packages (nomenclature, subjects, etc). Regards!
I totally support this idea!
For me it is still a bit of a mystery how to BEST create a library/package from your own files...
^
Yes x1000. While the syntax isn’t too hard to get my head around, best practices is always difficult to get a handle on. And most info on web is for open source projects. It’s actually quite difficult to get an idea of how to robustly share internal packages with the rest of your team in a non-open way.
+999 to this :)
agreed. i'd like to see that too
I cannot overstate how well you described the decorators in every aspect! Great work!
Thank you so much!
Thank you so much!
I came for the high quality and well thought out content. I stayed for it too. But I loved it for all of the glorious puns. :D Thank you for the education and the puns. Both are much appreciated!
Glad you enjoyed it!
One of the best channel for learning python best practices. Thanks alot Arjan!
Thank you, Tim, glad you find the content helpful!
This dude i can tell came from Java/C++ world he mastered OOP - this is a great for a seasoned developer. Thanks bro.
My python code always looks like it's straight out of the 90s and yours reminds me of something from another time completely. Definitely should brush up more :)
It's literally like you're spying on my current challenges at work! There's a heavily nested decorators function that is being used and this has cleared things up a lot! Thanks so much, keep going with the great work!
Thank you and will do!
I know the decorator pattern from top of my head, but I use python decorators so rarely I have to re-learn them every time :)
Another good use case for decorators is error handling. We catch different exceptions in a web app on different layers and turn them into http errors.
But overall decorators are a niche thing.
Turtles all the way down. Glad you mentioned the "harder to read" downside. Excellent presentation of a fun tool.
Thank you, glad you enjoyed it!
Omg, thought how to combine music with your videos - and here it comes. Much easier to switch from coding to learning now, nice feature:)
Welp. I guess I now know exactly what I need to rewrite part of a work project. There's some complicated and annoying interdependencies that I am not a fan of, but I hadn't figured out how to solve it.
Also, thanks for explaining something that as far as I could tell were just magic!
You're welcome, Marie! :)
Excellent presentation! I think I need to watch this two or three times to fully understand as this is a lot like the movie Inception, dreams within dreams… Thanks for putting the time into this content and also for the additional discussion at the end where you discussed practical use. Cheers!
I definitely agree that wrapping logic in decorators makes code harder to read, but I love using them to register handlers, like how Flask defines routes.
I use it like that all the time for event handlers, and I just think it makes the code super easy to read and understand.
Love your videos, so happy to see someone else who loves Python as much as I do 😁
BTW, flask's decorator functions also return the original function unchanged. So even though a function is a flask route, you can call it just like a regular function if needed.
Flask's types were broken regarding this fact, and I had to fix them sometime last year.
You asked if anyone was using their own decorators, so here goes. We're developing a Flask application with authentication, of course. We are using the Flask-provided login_required decorator but also require different roles for the users. This meant testing whether the user had the appropriate role at the beginning of certain routes. I decided this was essentially code duplication and really required a new decorator in which you supply a list of roles. Surprisingly easy to write, really. It's part of the code base and documented, so a future developer of the application should understand how and when to use it.
JIC: we also can implement decorators using class with `__init__` and `__call__` method (`__init__` for parameterizing and `__call__` for applying deco to func of class)
And in addition we can decorate not only functions but classes as well
This is the most practical advise on decorators i've ever seen or heard.
Thanks!
22:38 You shouldn’t have bothered with functools.partial. Just do
with_default_logging = with_logging(logger)
I liked the first part of your tutorial. It reminded me how I used to decorator before java 1.5, and instantly boosted my learning speed.
Thanks for sharing!
Easily the best presentation on decorators I’ve ever seen. 👏🏻
Wow! Thanks so much 😊
Great video. For anyone wanting to use the with_default_logging decorator, be aware of a potential issue. Most likely, the logger object will have the name from the module where it was instantiated. If you import it via decorator into another module, it might get confusing where the logging call actually came from because the logger name can be mistaken for the module name. I definitely had the issue in the past and it took me a while to figure out what was going on.
I have watched a few videos on this topic and you explained the best. It's so easy to understand with some background (classic decorator pattern in OOP and then how Python gets it done). Thank you.
Glad it was helpful!
This channel has the most useful python tutorials.
Decorators are truly a double edged sword. I have used them in the past to pass on a database session through multiple layers of controllers in a rest application. The decorator took ownership of the session and decided when to open / flush / commit / and close the session. It also added some parameters to every controller function in order to implement some security features. It worked wonders for our project as even after countless controller calls a session could seamlessly revert to an old state if an error occurred and controller functions were automatically secured, but to this day it confuses some developers when working with it, because not everyone understands python decorators well. Though I still stand to that design choice today.
Using decorators: 🙂
Designing decorators: 😨
This is the one of the most interesting and enlightening video within your playlist.
I am about to flex all these skills from your video into my code-base. 🤣
Go for it! 💪🏻
I started watching recently and I have been pleasantly surprised by the quality of your content. There is one caveat, I think, to using the @decorator syntax of python and that is if you need to provide different parameters to the wraper function in different moments. Since the decorator is set at the beginning of the definition of a function, you would either define a function multiple times with the decorator with updated parameters, or use one of the other ways to use a decorator as you showed in the video.
I just started getting into decorators, and this is such a comprehensive guide on what the hell a decorator is, thank you so much
You're so welcome!
As a functional programmer I love the functional decorator, combinators are good.
Realized now that Arjan codes is one of the only channels that when you ask for a like i actually stop and like the video. Thought goes like: "that's so useful, it really deserves a like" hehe
btw: i would like to see your deep dive on the import system ...
Thanks for your support! I noted your suggestion :)
Liked the video when I saw the like video button light up as soon as you talked about it. Nice!
Just way awesome than any video. Thank you loads Arjan ❤
Thank you so much 😀
One of your best videos yet
Finally understand how decorators work in detail
I was trying to accomplish a decorator in a class and couldn't make any sense of it until i saw this video.
Arjan explains the best and most generic way of achieving a decorator.
Thank you so much!
Thanks for the excellent and easy-to-follow explanation! Brilliant teaching :)
I'm glad to hear that the video was helpful :)
Really nice video! I discovered Decorators in my new job (C++), but we use the traditional pattern because we can change the order and list of them by the DI configuration tool or inside factories. Amazing how things like anticipation, sync or cached operations are decoupled from the model object.
THANK YOU 😊 Wanted something on this topic and just in time for lunch break today ! Gonna use it immediately
cette chaine est une mine d'or ! 🧡
Huge pain in the 'class' haha! Very nice!
Thanks. It is a great video explaining how decorator works. It is a good feature of dynamic programming language.
Thank you for the kind words! Glad you liked the video.
In my previous work, VW group, decorators were used to decorate classes and decorators created instances of classes that we wanted to use in the class. So they were some kind of Factories for other classes. I had no idea how that worked at the time :)
Great video, I use decorators all the time, but only the cases as you show in the video benchmarking and logging start of end of a method call.
Never use multiple decorators, if i need both timing and logging, i create a single decorator that does both
this is not always the case. there are quite well known frameworks which use stacked decorators frequently as middleware.
also order matters. if you have a number of decorators, do you want to write a decorator for every combination of them?
One of the best python video makers ever.. Keep going sir.. 😁 I have been following since so long, I'm a machine learning engineer and I come here once in a while, and always watch the latest ones to be sure my python skills are state of the art 😎
Thank you so much for your support!
For me the option that makes most sense is to use functions in the decorator design pattern. That way, if you're benchmarking code (say, in a jupyter environment) you can called the decorated functions of methods, but when you're deploying the code in a script that needs to run for hours and no one will look at, you can call the function without the decorator, thus leaving out a bunch of logging and calls to perf_time()
Thanks for the lesson Arjan. Very well done.
Glad you liked it!
I wrote a decorator for a web application once that enforced authorization. It would get the user session object from the coroutine context and verify that the user possessed the permissions defined in the decorator call. e.g. @secure('write_permission')
Great videos btw! I would appreciate a video on decorator classes. I've always found them very hard to understand how they work and what the pros/cons are. Oh, and a video on the coroutine context! Thanks!
Thanks, i like the path from classic patter to python’s decorator style.
Glad you like it!
I had a hard time understanding decorators in my high school days. Never created my own, but I think I might have to reconsider now
Danke!
Happy you enjoyed the video, Andreas!
Easy to follow and very helpfull!
Great to hear!
Exactly the video I was looking for. 🎉🎉
Glad I could help!
I'm learning from you a lot. Many thanks!
My pleasure!
Thank you so much for the videos!
Could you use more visuals (drawings) before writing the code? I guess if you draw what you are trying to build before building it, this will deliver the message perfectly
One notable case where I built my own decorators was to build a mini-ETL framework. I was using decorators to inject data validation checks pre and post transformation steps.
Also reused the @nested_dataclass trick someone posted online to be able to create dataclasses with nested dataclasses members off of unpacked dictionaries.
Do you have a link for that by chance?
Amazing content! Thanks so much for sharing that.
thanks this super insightful guide! much appreciated
Thank you!
Superb, like always.
Thanks so much!
Simply an amazing video 😌 Thank you.
Glad you enjoyed it, Diego!
An amazing tutorial!
Thanks
You're welcome!
The most useful tip with decorators especially in-case where a decorator handles input, for example in authentication the best
possible way to handle invalid input is to raise an Error : raise UnAuthenticatedError(message) then handle the error else where on your code, any other means of handling invalid arguments or invalid credentials is bound to cause problems with Flow.
for example if you handle invalid arguments by passing along a variable or credentials , then if they are invalid and you forget to handle the case where the credentials where invalid in the method or function in which the decorator is being used, you may not find this bug... straight away,
Yes, good points!
you are gods gift for me
thank you very much.
are not you planning for doing some projects in python.
Thanks Arjan!
You’re welcome!
great video, thx a million, making me revisit those ideas, i tend to forget ;)
Thank you, glad you liked it!
One more fantastic python guide. ❤️
You make it easy to learn.
Are you also going to tackle another programming language, like javascript?
Or will that hurt your UA-cam algorithm too much?
I expect mixing programming languages will hurt the channel. But I might start another channel in the future that focuses on a different programming language.
Absolutely great video
Thank you so much!
OH MY GOD IT FINALLY MAKES SENSE
Tak!
Thank you for your support, Cassidy!
I gave the like, a nice way to decorate!
I’ve decorated your comment as well 😎
Great video as always, I use the built in decorators but Ive never reach the point of making my own. It looks awesome but in practice I feel its a bit convoluted as an end user. I will definitely will try them out now. Thank you for the great video.
Glad you liked the video! 😊
Note that if you want decorators to support both sync and async functions, you can switch based on the value of inspect.iscoroutinefunction()
I recently implemented a version elevator system using decorators. The version elevators were just simple functions that take in a config object and modify it in-place updating it to the next highest version. The decorators were needed because some versions needed multiple mending functions due to inconsistend versioning plus we also had some functions that were just there to provide some convenience options in the configs. As such, the decorator would take the version for which the mending function should be applied as an argument or None it is a convenience thing. The decorator would then take care of adding logging and registering the mending function. Now, outdated configs can be updated by just running all the version escalators on it in the given order, e.g. if the config is version 3 and the current version is 5 it would be 3->4->5 and then run all of the convenience stuff. I think the decorators make the code quite tidy since all you see is really only the migration logic. I would recommend using the class-based approach with `__call__` when you want decorators that take arguments though. I find them easier to read than three nested functions and it makes dealing with defaults easier as well.
Thank you so much for your hard work and the effort you put into your channel. Great video!!!
Quick question/ idea for another video
Could you describe the difference between Decorator and Proxy Design patterns?
Thanks in advance!
Great suggestion!
I use decorators mostly for testing and debugging. Having a dedicated decorators for benchmark and logging produces less clutter and I can simply remove the decorator if I no longer need it. I also use my own @NOT_IMPLEMENTED decorator to automatically raise a NotImplemented exception and print message to the console, so I don't have to write the code manually in every function over and over.
Otherwise I try to stay away from decorators (unless it's property, dataclass or pytest fixture).
I really like functional programming and specially haskell. I often try to see how to reproduce haskell behavior in python for fun (and sometimes profit). Decorators were the obvious choice to implement currying. The not so obvious choice used by functools.partial (class) is much better, but requires more work to work properly.
Very good!
Thank you!
Decorators are a wonderful way to challenge people to explore the more abstract tools in Python and their also wonderful for making DRY-er code.
I recently used decorators to support a test structure, where the decorator would display information, e.g. pass/fail the return of all the test, given the test methods only returned bools.
Lovely vidoe as always
here is a video idea for you: How to Code inefficiently.
Haha, good suggestion, with some reverse psychology :)
I wanted to ask a question but writing my question answered it, thanks
powerfully awesome
He is back!!!
I usually use the decorators from packages, I didn't had the need to create stuff for myself.. but watching this video, I see there is a lot of small stuff I do a lot in my code that could be an decorator.. just low level stuff like error handling and logging..
Love it!
Thanks!!
I was hoping that you would talk about ParamSpec near the end to be able to preserve the argument types of decorated functions for better autocomplete :)
Several years ago the term "aspect oriented programming" was in vogue. Decorators seem to me _the_ way to implement AOP.
Everyone else is giving proper accolades for the video, so I just came in to say well done for "Pain in the Class" 😂👏
Haha, thank you Chris!
For logging I use loguru - a neat little library that saves me some time
17:55 No need to bring in yet another module. Just add this to the decorator functions:
wrapper.‗‗name‗‗ = func.‗‗name‗‗
this does not copy the entire function signature. just the name. annotations and docs are lost
@@dane2565 Easy enough to copy name and docstring. Annotations may not necessarily be valid.
This is extremely interesting, I am working on a Flask 2.0 project and would like to know if you have any videos on Flask. Search did not find anything apart from GarphQL VS Rest. Thank you.
Haven't done a video on Flask, but soon a video will come out on FastAPI.
@@ArjanCodes I look forward to it, thank you very much.
haha djeez 'pain in the class', you outdid yourself. Angry upvote.
You have my decoration.
Thank you, that brightens my day! 😎
Brilliant video. May I ask which IDE is that - that run button and auto switching to terminal is quite nifty.
Thanks! I'm using VS Code.
Hey, Can you make a video about the difference between decorator and proxy design patterns
Great Video Arjan. How would you implement an async decorator for async functions or a decorator that can be used on both sync and async. Still found a solution that "feels" right
Hi Arjan. Your code examples from git have small mistake. When you check for prime number you forget to convert stop elm to integer => for element in range(2, sqrt(number) + 1). sqrt return float thats lead to TypeError Exception
I notice you only talked about function decorators, not class decorators. They have their uses, too.
I think the most extensive use I have made of custom decorators so far has been in my DBussy package, a pure-Python wrapper for libdbus. The information defining the D-Bus interface to a Python class is specified via a function decorator on each Python method implementing a D-Bus interface method, with a class decorator to tie it all together. Then when you register your class to receive messages, the dispatch mechanism knows how to decode incoming D-Bus method calls, convert the arguments and dispatch to the appropriate Python method.
As a bonus, this same information is used to automatically generate the D-Bus XML introspection format, when another D-Bus peer sends you the introspection message. And conversely, when you introspect another D-Bus peer, this info is used to dynamically generate a “proxy interface class” -- a Python class whose methods simply send the appropriate D-Bus messages and return the responses.
I use decorators in fastapi for user's token authorization.