Sublime text3 and virtualenvs

Question:

I have different virtualenv‘s (made with virtualenwrapper) and I’d like to be able to specify which virtualenv to use with each project.

Since I’m using the SublimeREPL plugin for custom builds, how can I specify which python installation to build my project with?

For example, when I work on project A I want to run scripts with venvA’s python, and when I work on project B I want to run things with venvB (using a different build script).

Asked By: Doc

||

Answers:

You’re looking for custom build systems.

From the menu bar, click Tools -> Build Systems -> New Build System...

Fill out the template it gives and save it under any filename ending in .sublime-build to your User folder.

Here is the documentation for making custom build systems:

https://www.sublimetext.com/docs/3/build_systems.html

I recommend making a custom build system for python scripts, then add variants for each virtual env you want. (see variants https://www.sublimetext.com/docs/3/build_systems.html#option-variants)

One you make a build system, you can switch them from

Tools -> Build Systems

(if not auto detected) and use the Command Palette (default ctrl + shift p) to switch between variants.

The only "gotcha" is the "cmd" parameter to describe what command to run. By default it takes an array of strings to run as a command, but you can use "shell_cmd" instead to just use a string of how you would run it via command line.

Answered By: Allison

Hopefully this is along the lines you are imagining. I attempted to simplify my solution and remove some things you likely do not need.

The advantages of this method are:

  • Single button press to launch a SublimeREPL with correct interpreter and run a file in it if desired.
  • After setting the interpreter, no changes or extra steps are necessary when switching between projects.
  • Can be easily extended to automatically pick up project specific environment variables, desired working directories, run tests, open a Django shell, etc.

Let me know if you have any questions, or if I totally missed the mark on what you’re looking to do.

Set Project’s Python Interpreter

  1. Open our project file for editing:

     Project -> Edit Project
    
  2. Add a new key to the project’s settings that points to the desired virtualenv:

     "settings": {
         "python_interpreter": "/home/user/.virtualenvs/example/bin/python"
     }
    

A "python_interpreter" project settings key is also used by plugins like Anaconda.

Create plugin to grab this setting and launch a SublimeREPL

  1. Browse to Sublime Text’s Packages directory:

    Preferences -> Browse Packages...
    
  2. Create a new python file for our plugin, something like: project_venv_repls.py

  3. Copy the following python code into this new file:

    import sublime_plugin
    
    
    class ProjectVenvReplCommand(sublime_plugin.TextCommand):
        """
        Starts a SublimeREPL, attempting to use project's specified
        python interpreter.
        """
    
        def run(self, edit, open_file='$file'):
            """Called on project_venv_repl command"""
            cmd_list = [self.get_project_interpreter(), '-i', '-u']
    
            if open_file:
                cmd_list.append(open_file)
    
            self.repl_open(cmd_list=cmd_list)
    
        def get_project_interpreter(self):
            """Return the project's specified python interpreter, if any"""
            settings = self.view.settings()
            return settings.get('python_interpreter', '/usr/bin/python')
    
        def repl_open(self, cmd_list):
            """Open a SublimeREPL using provided commands"""
            self.view.window().run_command(
                'repl_open', {
                    'encoding': 'utf8',
                    'type': 'subprocess',
                    'cmd': cmd_list,
                    'cwd': '$file_path',
                    'syntax': 'Packages/Python/Python.tmLanguage'
                }
            )
    

Set Hotkeys

  1. Open user keybind file:

     Preferences -> Key Bindings - User
    
  2. Add a few keybinds to make use of the plugin. Some examples:

    // Runs currently open file in repl
    {
        "keys": ["f5"],
        "command": "project_venv_repl"
    },
    // Runs repl without any file
    {
        "keys": ["f6"],
        "command": "project_venv_repl",
        "args": {
            "open_file": null
        }
    },
    // Runs a specific file in repl, change main.py to desired file
    {
        "keys": ["f7"],
        "command": "project_venv_repl",
        "args": {
            "open_file": "/home/user/example/main.py"
        }
    }
Answered By: Soytoise

There is a sublime text3 package, named Virtualenv, allowing you to build using the Python from your virtualenv.

It supports any versions of Python in your virtualenv, and works very well for me (MacOS).

To install it, we just command+Shift+P to call out pacakge control (install it if you don’t have it yet), then type install. Next type virtualenv, when you see it appears click return to install it.

After installing it, select Tools –> Build System –> Python + Virtualenv. Then you can use command + B to execute your Python projects.

Click Here to check further information.

Answered By: Jay Wong

I have an alternative. Just creating a new ‘Build System’ which runs as if in the virtual environment. Here we call it ‘my_python’. The aim is to use this build system to run my script directly without leaving sublime. You need to:

  1. First, preferences->Browse Packages. This will open a folder under which lies setting files. Go inside dir User and create a new file named my_python.sublime-build (composed of the build system name followed by .sublime_build. After doing this, go to Tools -> Build System and you will see a new option my_python.
  2. Add the following JSON settings to that file.

    {
        "shell_cmd": "/Users/Ted/bsd/vector/.v_venv/bin/python -u "$file"",
        "file_regex": "^[ ]*File "(...*?)", line ([0-9]*)",
        "selector": "source.python"
    }
    

    Inside shell_cmd, change /Users/Ted/bsd/vector/.v_venv/bin/python to the path of your python virtual environment.

  3. Then just use the short key to build your script.

When you want to change your virtual environment, just copy its path to the setting file and all done. Maybe the approach seems containing a lots of work, but it works well and convenient.

Answered By: Guohua Cheng

I’m a super newb to Python, pipenv, and especially Sublime Text 3. Couldn’t find a simple solution to get me started working with pipenv virtual environment and sublime on Windows 10.

This works really well for someone who doesn’t have much systems experience.

My setup:

 Windows 10 Pro
 Python 3.9
 Sublime Text 3
 Dedicated directory for Python virtual environment 'C:UsersusernameVirtualEnvs`
 
  1. create a virtual environment using pipenv in a dedicated directory: pipenv install BestPythonPackage
  2. from the dedicated directory run: pipenv shell
  3. get the virtual environment path; while in the shell run: pipenv --venv
  4. open folder in sublime
  5. create new project: Project > Save Project As > "New Project Name"
  6. select "New Project Name".sublime-project from file list in left column
  7. replace contents of that file with the below and save. The path is what you found from running ‘pipenv –venv’
{
    "folders":
    [
        {
            "path": "C:\Users\username\.virtualenvs\PythonEnvs-uKL8m4_g",           
        },
    ],
    
    "build_systems": [
      {
      "name": "PYTHON_PIPENV",
      "cmd": ["python", "$file"],     
      }
    ], 
}
  1. Observe the sublime folder name for your dedicated folder has changed to the name of the virtual environment.

  2. Create a ‘hello.py’ program from the folder.

  3. build the program with Tools > Build System > "PYTHON_PIPENV" build system now in the list.

Of course, the caveat here is you’d need to do this for any new virtual environment. Some of the other solutions provided will dynamically update. Those were/are over my head at the moment. This is a simple solution.

‘folders’ section tells sublime what directory to look at
‘build_systems’ gives a name for the new config, and tells sublime to run ‘python’ on whatever file you have open.

Answered By: Dougmill