ctrl+shift+p filters: :st2 :st3 :win :osx :linux
Browse

Line​Profiler

Line-based Python profiling plugin for Sublime Text

Details

  • 2021.01.11.16.17.27
  • github.​com
  • github.​com
  • 3 years ago
  • 46 minutes ago
  • 11 years ago

Installs

  • Total 900
  • Win 461
  • Mac 249
  • Linux 190
Apr 20 Apr 19 Apr 18 Apr 17 Apr 16 Apr 15 Apr 14 Apr 13 Apr 12 Apr 11 Apr 10 Apr 9 Apr 8 Apr 7 Apr 6 Apr 5 Apr 4 Apr 3 Apr 2 Apr 1 Mar 31 Mar 30 Mar 29 Mar 28 Mar 27 Mar 26 Mar 25 Mar 24 Mar 23 Mar 22 Mar 21 Mar 20 Mar 19 Mar 18 Mar 17 Mar 16 Mar 15 Mar 14 Mar 13 Mar 12 Mar 11 Mar 10 Mar 9 Mar 8 Mar 7
Windows 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Mac 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Linux 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Readme

Source
raw.​githubusercontent.​com

LineProfiler

This plugin exposes a simple interface to line_profiler and kernprof inside Sublime Text.

Installation

LineProfiler is available via Package Control, which is the easiest way to install it. Alternatively, you can download this repository and place it in your Packages directory.

Configuration

  1. Install line_profiler and kernprof.py.
  2. Optional: Update LineProfiler's settings
    • Accessible at (Preferences > Package Settings > LineProfiler > “Settings - User”)

Available preferences are:

  • kernprof: (Optional) path to the kerprof.py file you downloaded alongside the line_profiler module.
  • pythonpath: (Optional) colon-separated list of paths that will be appended to the start of the the default PYTHONPATH.
  • poll_timeout_seconds: (Optional) number of seconds to wait before killing the profiler. If you're profiling code that runs for longer than a minute, increase this value.
  • poll_sleep_seconds: (Optional) number of seconds to sleep before polling the profiler for results. If you find the delay in getting profiler results too long, decrease this value.

Usage

Add the @profile annotation to any functions you'd like to profile. Then, run the plugin via the available bindings: * ctrl-alt-shift-p * right-click > “Run line_profiler” * Tools > Packages > “Run line_profiler”

If successful, a scratch buffer will appear with your results. If not, check the console (ctrl-`) to see any error messages.

The profiler runs in a background process, so Sublime will continue operating normally until a result is returned.

Example

Here's a simple way to try out LineProfiler and get familiar with the plugin.

Step 1: Open Sublime and write a simple Python file:

def foo():
  for i in xrange(1000):
    bar = i**2
    baz = i*i

if __name__ == '__main__':
  foo()

Sure, it doesn't do much, but it'll run. Be sure to tell Sublime that it's Python code, either by saving it as a .py file, or selecting Python in the bottom bar.

Step 2: Add the @profile decorator to the foo function, like so:

@profile
def foo():

(Everything else is unchanged.)

Step 3: Run LineProfiler, either from the Command Palette, the right-click menu, or the keyboard shortcut. The command is only available in Python mode, so check that first.

Step 4: Wait about a second, and then watch as the profile results appear in a new tab. If all went well, you should see the lines of the foo function annotated with their run counts, total time, and time per run:

function foo in file tmpev_rzr.py took 0.001248 s

Line #      Hits         Time  Per Hit   % Time  Line Contents
==============================================================
     2                                           @profile
     3                                           def foo():
     4      1001          372      0.4     29.8    for i in xrange(1000):
     5      1000          458      0.5     36.7      bar = i**2
     6      1000          418      0.4     33.5      baz = i*i

Some lines may be highlighted. These are “hot spots” in your code, which take up a disproportionate amount of time.

If you don't see anything after a second, check the console (ctrl-`) to see what went wrong. Often, the issue is a simple matter of setting the right paths in the user settings file.