Useful python – Class based decorators and context managers

There are many things why Pyhton is my standard go-to language if it comes to implement something. It’s either a website, automation, data-mining or complex calculation Python excels in most of it. I decided to write some of my favourite things which just makes things cleaner and easier to implement.

1. Class based decorators and context managers

I’ve already wrote a post where I mentioned the power of decorators. Now I want to take it to a step further. In spite of the most example can be found online decorators can be written as classes simply because everything in Python is an object. You just need to specify the __call__ method as you would do it with your function.

However sometimes you already have one (or more) decorator around your functions and it’s not really good to overdecorate your functions. Also you might not want to create a separate function because only small part of your method needs to be wrapped with the decorator’s behaviour. For example timeout. This is where context managers come into play.

Just like for examples Django’s transaction contexts your decorators can be written in a way that it can be used as a with context as well.

Here is a simple example:

In both cases we’re going to get timeout.TimeoutException.

So how to implement this? The only trick is you need the __enter__ and __exit__ for the context manager behaviour and __call__ for the decorator. Here’s a simple example:


You might like these too

Solr python interface – Sunburnt fork I forked tow (Toby White, gratitude for his great work) sunburnt repository from github because I needed range facet funcionality and the workaround (...
BitTornado library forked by me on GitHub I just forked and committed some patches to the BitTornado library on GitHub. Right now I only committ...
Python error: AttributeError: __exit__ I just had a 30 minutes worth of debugging on a stupid mistake I made. I wanted to check the free space on the target server before I actually start t...