Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

decorator

License

NotificationsYou must be signed in to change notification settings

micheles/decorator

Repository files navigation

The goal of the decorator module is to make it easy to definesignature-preserving function decorators and decorator factories.It also includes an implementation of multiple dispatch and other niceties(please check the docs). It is released under a two-clausesBSD license, i.e. basically you can do whatever you want with it but I am notresponsible.

Installation

If you are lazy, just perform

$ pip install decorator

which will install just the module on your system.

If you prefer to install the full distribution from source, includingthe documentation, clone theGitHub repo or download thetarball, unpack it and run

$ pip install .

in the main directory, possibly as superuser.

Testing

If you have the source code installation you can run the tests with

$ python tests/test.py -v

or (if you have setuptools installed)

$ python setup.py test

Notice that you may run into trouble if in your system thereis an older version of the decorator module; in such a case remove theold version. It is safe even to copy the module decorator.py overan existing one, since we kept backward-compatibility for a long time.

Repository

The project is hosted on GitHub. You can look at the source here:

https://github.com/micheles/decorator

Documentation

The documentation has been moved tohttps://github.com/micheles/decorator/blob/master/docs/documentation.md

From there you can get a PDF version by simply using the printfunctionality of your browser.

Here is the documentation for previous versions of the module:

https://github.com/micheles/decorator/blob/4.3.2/docs/tests.documentation.rsthttps://github.com/micheles/decorator/blob/4.2.1/docs/tests.documentation.rsthttps://github.com/micheles/decorator/blob/4.1.2/docs/tests.documentation.rsthttps://github.com/micheles/decorator/blob/4.0.0/documentation.rsthttps://github.com/micheles/decorator/blob/3.4.2/documentation.rst

For the impatient

Here is an example of how to define a family of decorators tracing slowoperations:

fromdecoratorimportdecorator@decoratordefwarn_slow(func,timelimit=60,*args,**kw):t0=time.time()result=func(*args,**kw)dt=time.time()-t0ifdt>timelimit:logging.warning('%s took %d seconds',func.__name__,dt)else:logging.info('%s took %d seconds',func.__name__,dt)returnresult@warn_slow# warn if it takes more than 1 minutedefpreprocess_input_files(inputdir,tempdir):    ...@warn_slow(timelimit=600)# warn if it takes more than 10 minutesdefrun_calculation(tempdir,outdir):    ...

Enjoy!


[8]ページ先頭

©2009-2025 Movatter.jp