Я не так давно начал изучать Python, и решил,  что мне необходима портативная сборка.  Причин для этого несколько, но статья не об этом. Если вам такое не нужно, дальше можно не читать. Во время поисков решения этой задачи часто сталкивался с вопросами людей по этой теме, но однозначного решения так и не нашел, но ответы некоторых пользователей натолкнули на верное решение. Почему VS Code? Ну, просто у них есть версия “portable”, так она гордо называется на сайте, но скачав ее, возникает вопрос, а как к тебе приделать Python?

 Сразу оговорюсь, целью было сделать полноценно переносную версию из связки Python + среда разработки + Git (для изучения).  В статье все расписал максимально подробно, так же на github закину файлы со всеми изменениями, и вам останется только создать структуру каталогов как у меня. Если хотите все разложить по своему- читайте-исправляйте,  по аналогии думаю не сложно будет сделать под себя.

Что нам потребуется:

  1. Winpython

  2. Cmder full – замена командной строке

  3. VS code portable - качаем по ссылке .zip нужной разрядности, но для универсальности лучше 32бит

Если вам не нужен Git или Cmder их можно не добавлять, так же можно добавить portable Git отдельно, добавляется по аналогии с Cmder.

Настройка WinPython

Извлекаем Winpython в любое удобное место. Я ставил версию Winpython32-3.8.10.0dot, она последняя поддерживает Windows 7. После извлечения папку назвал ” WPy32-38”, можете обозвать как нравится, но дальше в статье я буду ее называть так.

И так заходим в нашу папку “WPy32-38”, дальше нас интересует папка “t” вот в нее мы и извлекаем Cmder и VS code. Это уже обязательное условие.

После извлечения VS Code настраиваем по инструкции с оф.сайта, так же это сработает и для миграции уже установленного VS Code. Для портативной версии достаточно внутри папки VS Code создать папку ”data” и в ней папку “user-data”.  

Должно получится как-то так:

|- VSCode-win32-x64-1.25.0-insider

|   |- Code.exe (or code executable)

|   |- data

|   |   |- user-data

|   |   |   |- ...

Cmder просто извлекаем рядом с VS code. Папку с проектами я разместил рядом с WPy32-38, были разные варианты размещения, для быстрой активации Venv, но полноценного варианта так и не нашел, об этом подробнее в конце статьи.

|- WPy32-38

|   |- projekt

|   |- t 

|   |   |- VSCode

|   |   |- Cmder

С размещением файлов и папок разобрались, теперь все это надо прописать.

Первым делом открываем блокнотом  файл "..\..\WPy32-38\scripts\env.bat"

Там много чего расписано, можете посмотреть и разобраться самостоятельно. Добавляем код ниже там же где находятся подобные блоки.  Первый блок отвечает за Cmder, второй за Git. Если вы решили их не добавлять,сразу переходите к настройке VS Code.

Помните я писал что расположение важно? Так вот если у вас пути к папкам свои исправляем на данном этапе. Этот код располагаем после 55 строки примерно, между другими подобными блоками

Это для установки папки с Cmder

rem ******************
rem handle Cmder if included
rem ******************
if not exist "%WINPYDIRBASE%\t\cmder\vendor\" goto cmder_bad
set CMDER_HOME=%WINPYDIRBASE%\t\cmder\vendor\
set CMDER_EXE=init.bat
set CMDER=%CMDER_HOME%%CMDER_EXE%
set CMDER_PKGDIR=%WINPYDIRBASE%\cmder\
:cmder_bad

Это для установки папки с Git

rem ******************
rem handle GIT if included
rem ******************
if not exist "%WINPYDIRBASE%\t\cmder\vendor\git-for-windows\cmd\" goto git_bad
set GIT_HOME=%WINPYDIRBASE%\t\cmder\vendor\git-for-windows\cmd\
set GIT_EXE=git.exe
set GIT=%GIT_HOME%%GIT_EXE%
set GIT_PKGDIR=%WINPYDIRBASE%\t\cmder\vendor\git-for-windows\
:git_bad

Так же после строки   ” if %ERRORLEVEL% NEQ 0” (у меня это 26 строка) в поле “set”  дописываем пути к Cmder и Git, можете просто заменить этим:

set "PATH=%WINPYDIR%\Lib\site-packages\PyQt5;%WINPYDIR%\Lib\site-packages\PySide2;%WINPYDIR%\;%WINPYDIR%\DLLs;%WINPYDIR%\Scripts;%WINPYDIR%\..\t;%WINPYDIR%\..\t\mingw32\bin;%WINPYDIR%\..\t\R\bin\i386;%WINPYDIR%\..\t\cmder\vendor;%WINPYDIR%\..\t\cmder\vendor\git-for-windows;%WINPYDIR%\..\t\cmder\vendor\git-for-windows\cmd;%WINPYDIR%\..\t\cmder\vendor\git-for-windows\bin;%WINPYDIR%\..\t\cmder\vendor\git-for-windows\mingw32\bin;%WINPYDIR%\..\t\Julia\bin;%WINPYDIR%\..\n;%PATH%;"

На данном этапе все настройки для WinPython мы сделали.

Переходим к настройке VS Code

Для запуска используем ..\WPy32-38\VS Code.exe. Возможно при первом запуске будут ошибки, пока их просто игнорируем и открываем настройки.

 ..\WPy32-38\t\VSCode\data\user-data\User\ settings.json

// Указываем путь для питона
"python.interpreterPath": "${env:WINPYDIR}\\\\python.exe",

// Указываем путь для для проектов и соответсвенно для “venv”
 "python.venvPath": "${workspacefolder}/.venv",
 "python.venvFolders": [
      ".venv",
      "${workspacefolder}/.venv"

// Указываем путь до Cmder 
"terminal.integrated.profiles.windows": {
        "Cmder": {
          "path": "${env:windir}\\System32\\cmd.exe",
          "args": ["/k", "${env:WINPYDIRBASE}\\t\\cmder\\vendor\\init.bat"]
        },

// Тут путь для GIT, и соотвественно появится выбор командной строки GIT,можно не добавлять.
        "GIT": {
          "path": "${env:WINPYDIRBASE}\\t\\cmder\\vendor\\git-for-windows\\git-cmd.exe",
        }
      },

//Устанавливаем Cmder по умолчанию
  "terminal.integrated.defaultProfile.windows": "Cmder",
 
//Активируем GIT
   "git.enabled": true

//Прописываем путь до GIT
    "git.path": "${env:WINPYDIRBASE}\\t\\cmder\\vendor\\git-for-windows\\cmd\\git.exe",

После сохранения требуется перезапуск VS Code.

Проверка прописанных модулей

Для проверки открываем командную строку “Ctrl+~” , если видите там лямбду, Cmder подцепился и работает. Пишем в командной строке git --version, получили версию, значит и git нормально прописали.

Пробуем запускать проект и проверяем активировался ли venv, если нет, то проверяем предлагает ли VS Code его как рекомендуемый. Опять нет? Тут я нашел только один вариант, если вы знаете что виртуальная среда создавалась в этой же версии питона, то просто вводим в терминале VS Code : python –m venv venv и делаем перезапуск VS Code, но зависимости ставить повторно не придется. Так же не могу сказать как активировать виртуальную среду другой версии. Просто, по какой-то причине, стандартная команда для активации venv у меня не срабатывает. Тут уже тестируйте-смотрите. Возможно кто-то подскажет путь решения данной проблемы.

Прошу строго не судить, первая моя статья, надеюсь кому-то будет полезной.

Комментарии (4)


  1. Anshi85
    01.04.2022 06:58
    +1

    Причин для этого несколько, но статья не об этом. Если вам такое не нужно, дальше можно не читать.

    Могли бы привести причины, а то звучит "я тут кое что придумал, зачем я это придумал не скажу и вообще проходите мимо", мне было бы интересно какие сценарии использования такой сборки у вас, может тоже взял бы на вооружение.


    1. mpkkii Автор
      01.04.2022 07:41
      +1

      Ну тут все просто, мне приходится часто работать за разными компьютерами, ставить на все python, git, ide, каждый раз клонировать репо, ставить зависимости- это было бы не рационально, учитывая то, что на данный момент это используется для обучения. А так все всегда с собой и готово к запуску.


    1. red_dragon
      01.04.2022 07:53
      +2

      Просто у человека нету собственного компьютера, скорее всего. Так бывает. На это обстоятельство можно сверху натянуть множество причин. Не грейте голову.


  1. slipers
    01.04.2022 11:21

    Если честно сейчас (раньше то же страдал подобными извращениями тратя на это уйму времени) хватает виртуалки под qemu. Tiny Core Linux + все необходимое (600Mb).
    Попробуйте установка всего что нужно займет 30 минут.