{"id":28381355,"url":"https://github.com/sinusphi/venvipy","last_synced_at":"2026-02-11T03:11:44.494Z","repository":{"id":290683753,"uuid":"197188037","full_name":"sinusphi/venvipy","owner":"sinusphi","description":"A GUI for managing Python virtual environments","archived":false,"fork":false,"pushed_at":"2026-02-09T11:37:42.000Z","size":362537,"stargazers_count":52,"open_issues_count":0,"forks_count":7,"subscribers_count":2,"default_branch":"main","last_synced_at":"2026-02-09T16:28:01.456Z","etag":null,"topics":["gui","pyqt","pyqt5","pyqt5-desktop-application","python","python3","venv","virtualenvironment"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"gpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/sinusphi.png","metadata":{"files":{"readme":"README.rst","changelog":null,"contributing":null,"funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null},"funding":{"github":"sinusphi","ko_fi":"sinusphi","custom":["paypal.me/yserestou"]}},"created_at":"2019-07-16T12:16:49.000Z","updated_at":"2026-02-09T11:37:45.000Z","dependencies_parsed_at":null,"dependency_job_id":"c57d8d0f-d5d3-4278-8c5c-26cbc60dbd08","html_url":"https://github.com/sinusphi/venvipy","commit_stats":null,"previous_names":["sinusphi/venvipy"],"tags_count":24,"template":false,"template_full_name":null,"purl":"pkg:github/sinusphi/venvipy","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sinusphi%2Fvenvipy","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sinusphi%2Fvenvipy/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sinusphi%2Fvenvipy/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sinusphi%2Fvenvipy/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/sinusphi","download_url":"https://codeload.github.com/sinusphi/venvipy/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sinusphi%2Fvenvipy/sbom","scorecard":{"id":827425,"data":{"date":"2025-08-11","repo":{"name":"github.com/sinusphi/venvipy","commit":"0958466c49e3dff396a3c6a5224609c1347eb956"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":2.9,"checks":[{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Maintained","score":4,"reason":"5 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 4","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Dangerous-Workflow","score":-1,"reason":"no workflows found","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Token-Permissions","score":-1,"reason":"No tokens found","details":null,"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"Code-Review","score":0,"reason":"Found 1/21 approved changesets -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Pinned-Dependencies","score":-1,"reason":"no dependencies found","details":null,"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: GNU General Public License v3.0: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'main'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"Vulnerabilities","score":5,"reason":"5 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: PYSEC-2014-14 / GHSA-652x-xj99-gmcc","Warn: Project is vulnerable to: GHSA-9hjg-9r4m-mvj7","Warn: Project is vulnerable to: GHSA-9wx4-h78v-vm56","Warn: Project is vulnerable to: PYSEC-2014-13 / GHSA-cfj3-7x9c-4p3h","Warn: Project is vulnerable to: PYSEC-2018-28 / GHSA-x84v-xcm2-53pg"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}},{"name":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 11 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}}]},"last_synced_at":"2025-08-23T16:53:38.256Z","repository_id":290683753,"created_at":"2025-08-23T16:53:38.256Z","updated_at":"2025-08-23T16:53:38.256Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":29326079,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-02-11T02:08:56.257Z","status":"ssl_error","status_checked_at":"2026-02-11T02:08:51.338Z","response_time":97,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["gui","pyqt","pyqt5","pyqt5-desktop-application","python","python3","venv","virtualenvironment"],"created_at":"2025-05-30T04:04:51.450Z","updated_at":"2026-02-11T03:11:44.484Z","avatar_url":"https://github.com/sinusphi.png","language":"Python","funding_links":["https://github.com/sponsors/sinusphi","https://ko-fi.com/sinusphi","paypal.me/yserestou","https://paypal.me/yserestou"],"categories":[],"sub_categories":[],"readme":".. image:: https://raw.githubusercontent.com/sinusphi/venvipy/main/img/cover_slim.png\n   :alt: VenviPy cover\n\nVenviPy\n=======\n\n**A GUI for managing multiple Python virtual environments**\n\n.. image:: https://img.shields.io/pypi/v/venvipy?logo=pypi\u0026logoColor=gold\u0026color=darkcyan\n    :target: https://pypi.org/project/venvipy/\n\n.. image:: https://img.shields.io/badge/python-3.7%2B-blue?logo=python\u0026logoColor=gold\n    :target: https://www.python.org/downloads/\n\n.. image:: https://img.shields.io/badge/pyqt-6.10.2-darkgreen?logo=qt\u0026logoColor=green\n    :target: https://pypi.org/project/PyQt6/6.10.2/\n\n.. image:: https://pepy.tech/badge/venvipy\n    :target: https://pepy.tech/project/venvipy\n\n.. offf image:: https://img.shields.io/badge/platform-linux-orange?logo=linux\u0026logoColor=FFE873\n    :target: https://www.linux.org/pages/download/\n\n.. image:: https://img.shields.io/badge/code%20style-black-000000\n    :target: https://github.com/psf/black\n\n.. image:: https://img.shields.io/badge/license-GPL%203.0-darkviolet\n    :target: https://github.com/sinusphi/venvipy/blob/main/LICENSE\n\n.. image:: https://img.shields.io/badge/donations-paypal-darkblue?logo=paypal\u0026logoColor=darkblue\n    :target: https://paypal.me/yserestou\n\n|\n\nIntroduction\n------------\n\n*VenviPy* is a desktop GUI to create, manage, and maintain many Python virtual\nenvironments from one place. It focuses on a fast, practical workflow:\n\n* create environments via a wizard (Python version, location, pre-install packages)\n* keep an overview table of all environments in a directory\n* manage multiple environments at the same time with tabs\n* install / update / inspect packages with context-menu actions\n* open a console in the environment's context with one click\n\nVenviPy was originally built for \\*NIX systems. Windows support exists via a\nplatform abstraction layer, but should currently be considered experimental.\n\n|\n\nScreenshots\n-----------\n\n**Main menu**\n\n.. image:: https://raw.githubusercontent.com/sinusphi/venvipy/refs/heads/main/img/screen-1_1.png\n   :alt: Application Main menu screenshot\n\n|\n\n.. image:: https://raw.githubusercontent.com/sinusphi/venvipy/refs/heads/main/img/screen-1_2.png\n   :alt: Application Main menu screenshot\n\n|\n\n**Wizard**\n\n.. image:: https://raw.githubusercontent.com/sinusphi/venvipy/refs/heads/main/img/screen-2_1.png\n   :alt: Wizard screenshot 1\n\n|\n\n.. image:: https://raw.githubusercontent.com/sinusphi/venvipy/refs/heads/main/img/screen-2_2.png\n   :alt: Wizard screenshot 2\n\n|\n\n**Package installer**\n\n.. image:: https://raw.githubusercontent.com/sinusphi/venvipy/refs/heads/main/img/screen-4_1.png\n   :alt: Package installer screenshot 1\n\n|\n\n.. image:: https://raw.githubusercontent.com/sinusphi/venvipy/refs/heads/main/img/screen-4_2.png\n   :alt: Package installer screenshot 2\n\n|\n\n**Console output**\n\n.. image:: https://raw.githubusercontent.com/sinusphi/venvipy/refs/heads/main/img/screen-3.png\n   :alt: Console output screenshot\n\n|\n\nKey Features\n------------\n\nEnvironment management\n~~~~~~~~~~~~~~~~~~~~~~\n\n* Create virtual environments with a selectable Python version (3.3+)\n* Clone an environment from a requirements file\n* Generate requirements from an existing environment\n* Add a description to an environment\n\nPackage management\n~~~~~~~~~~~~~~~~~~\n\n* Install and update Pip and Wheel with one click\n* Search and install packages from `PyPI \u003chttps://pypi.org/\u003e`__\n* Install from requirements files\n* Install from local project directories\n* Install from a VCS URL *(currently git only)*\n* Install from local or remote source archives\n\nInspection \u0026 tooling\n~~~~~~~~~~~~~~~~~~~~\n\n* List detailed information about installed packages\n* Open a project's PyPI page in your browser. \n\nRoadmap ideas\n~~~~~~~~~~~~~\n\n* Add option to create a launcher and add it for example to your taskbar or startmenu\n* Run scripts in the environment's context\n* Uninstall packages in a selected environment in Package Manager\n* Clone environments, created by non-installed Python versions and has no requirements file\n\nMore to come.\n\n|\n\nPrerequisites\n-------------\n\n* Python **3.7+** (PyQt6 6.10.2 requires Python \u003e= 3.7)\n* A working ``venv`` module for the Python versions you want to use\n\nQuick start\n-----------\n\nIf you already have Python and pip available, this is the fastest path:\n\n.. code-block:: bash\n\n    python -m venv .venv\n    source .venv/bin/activate  # Windows (PowerShell): .venv\\Scripts\\Activate.ps1\n    pip install -U pip\n    pip install venvipy\n    venvipy\n\nFor full setup details and platform-specific notes, continue below.\n\nLinux (Debian/Ubuntu)\n~~~~~~~~~~~~~~~~~~~~~\n\nInstall the basics:\n\n.. code-block:: bash\n\n    sudo apt update\n    sudo apt install python3-pip python3-venv\n\nIf you want to create venvs for a specific Python version, install its ``-venv`` package as well\n(example for Python 3.10):\n\n.. code-block:: bash\n\n    sudo apt install python3.10-venv\n\nWindows\n~~~~~~~\n\nInstall Python from python.org and make sure it is on ``PATH``. No additional system packages are required.\n\n|\n\nInstallation\n------------\n\nInstalling into the system Python is discouraged. Use a dedicated venv (recommended) or ``pipx``.\n\nRecommended: install into a venv\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n.. code-block:: bash\n\n    python -m venv .venv\n\n    # on Linux/macOS:\n    source .venv/bin/activate\n\n    # on Windows (PowerShell):\n    # .venv\\\\Scripts\\\\Activate.ps1\n\n    pip install -U pip\n    pip install venvipy\n\n|\n\nDevelopment version (GitHub):\n\n.. code-block:: bash\n\n    pip install -U pip\n    pip install git+https://github.com/sinusphi/venvipy.git\n\n|\n\nAlternative: install with pipx\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n.. code-block:: bash\n\n    pipx install venvipy\n\n|\n\nUsage\n-----\n\nAfter installation you get the entry point:\n\n.. code-block:: bash\n\n    venvipy\n\n|\n\nFor command line options run:\n\n.. code-block:: bash\n\n    venvipy --help\n\n|\n\nRunning from source\n-------------------\n\nClone and install dependencies:\n\n.. code-block:: bash\n\n    git clone --depth 50 https://github.com/sinusphi/venvipy.git\n    cd venvipy\n    python -m venv .venv\n\n    # on Linux/macOS:\n    source .venv/bin/activate\n\n    # on Windows (PowerShell):\n    # .venv\\\\Scripts\\\\Activate.ps1\n\n    pip install -U pip\n\n    # minimal requirements to run VenviPy\n    pip install -r requirements/base.txt\n\n    # for development and testing\n    pip install -r requirements/dev.txt\n\n    # deployment and build dependencies\n    pip install -r requirements/deploy.txt\n\n|\n\nIf you prefer a minimal manual install:\n\n.. code-block:: bash\n\n    pip install requests beautifulsoup4 PyQt6==6.10.2\n\n|\n\nRun:\n\n.. code-block:: bash\n\n    python venvipy/venvi.py\n\n|\n\nContributing\n------------\n\nContributions are welcome:\n\n* `Pull requests \u003chttps://github.com/sinusphi/venvipy/pulls\u003e`__\n* `Bug reports \u003chttps://github.com/sinusphi/venvipy/issues\u003e`__\n* `Feature requests \u003chttps://github.com/sinusphi/venvipy/issues\u003e`__\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsinusphi%2Fvenvipy","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fsinusphi%2Fvenvipy","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsinusphi%2Fvenvipy/lists"}