.. pipenv documentation master file, created by sphinx-quickstart on Mon Jan 30 13:28:36 2017. You can adapt this file completely to your liking, but it should at least contain the root `toctree` directive. Pipenv: Sacred Marriage of Pipfile, Pip, & Virtualenv ===================================================== .. image:: https://img.shields.io/pypi/v/pipenv.svg :target: https://pypi.python.org/pypi/pipenv .. image:: https://img.shields.io/pypi/l/pipenv.svg :target: https://pypi.python.org/pypi/pipenv .. image:: https://img.shields.io/pypi/wheel/pipenv.svg :target: https://pypi.python.org/pypi/pipenv .. image:: https://img.shields.io/pypi/pyversions/pipenv.svg :target: https://pypi.python.org/pypi/pipenv .. image:: https://travis-ci.org/kennethreitz/pipenv.svg?branch=master :target: https://travis-ci.org/kennethreitz/pipenv .. image:: https://img.shields.io/badge/SayThanks.io-☼-1EAEDB.svg :target: https://saythanks.io/to/kennethreitz --------------- **Pipenv** is an experimental project that aims to bring the best of all packaging worlds to the Python world. It harnesses `Pipfile `_, `pip `_, and `virtualenv `_ into one single toolchain. It features very pretty terminal colors. It automatically creates and manages a virtualenv for your projects, as well as adds/removes packages from your ``Pipfile`` as you install/uninstall packages. The ``lock`` command generates a lockfile (``Pipfile.lock``). .. image:: http://media.kennethreitz.com.s3.amazonaws.com/s8.gif ☤ Features ---------- - **Automatically generates and checks file hashes for locked dependencies.** - Automatically finds your project home, recursively, by looking for a ``Pipfile``. - Automatically generates a ``Pipfile``, if one doesn't exist. - Automatically generates a ``Pipfile.lock``, if one doesn't exist. - Automatically creates a virtualenv in a standard location (``project/.venv``). - Automatically adds packages to a Pipfile when they are installed. - Automatically removes packages from a Pipfile when they are un-installed. - Also automatically updates pip. The main commands are ``install``, ``uninstall``, and ``lock``, which generates a ``Pipfile.lock``. These are intended to replace ``$ pip install`` usage, as well as manual virtualenv management (to activate a virtualenv, run ``$ pipenv shell``). Basic Concepts ////////////// - A virtualenv will automatically be created, when one doesn't exist. - When no parameters are passed to ``install``, all packages ``[packages]`` specified will be installed. - To initialize a Python 3 virtual environment, run ``$ pipenv --three``. - To initialize a Python 2 virtual environment, run ``$ pipenv --two``. - Otherwise, whatever virtualenv defaults to will be the default. Other Commands ////////////// - ``shell`` will spawn a shell with the virtualenv activated. - ``run`` will run a given command from the virtualenv, with any arguments forwarded (e.g. ``$ pipenv run python``). - ``check`` asserts that PEP 508 requirements are being met by the current environment. Shell Completion //////////////// Set ``_PIPENV_COMPLETE`` and then source the output of the program. For example, with fish, put this in your ``~/.config/fish/completions/pipenv.fish``:: eval (env _PIPENV_COMPLETE=source-fish pipenv) Magic shell completions are now enabled! Caveats /////// - Windows is not currently supported. ☤ Usage ------- :: $ pipenv Usage: pipenv [OPTIONS] COMMAND [ARGS]... Options: --where Output project home information. --bare Minimal output. --three / --two Use Python 3/2 when creating virtualenv. --version Show the version and exit. --help Show this message and exit. Commands: check Checks PEP 508 markers provided in Pipfile. install Installs a provided package and adds it to... lock Generates Pipfile.lock. run Spawns a command installed into the... shell Spawns a shell within the virtualenv. uninstall Un-installs a provided package and removes it... update Updates pip to latest version, uninstalls all... :: $ pipenv --where Pipfile found at /Users/kennethreitz/repos/kr/pip2/test/Pipfile. Considering this to be the project home. :: $ pipenv install Creating a virtualenv for this project... ... No package provided, installing all dependencies. Virtualenv location: /Users/kennethreitz/repos/kr/pip2/test/.venv Installing dependencies from Pipfile.lock... ... To activate this project's virtualenv, run the following: $ pipenv shell .. toctree:: :maxdepth: 2 :caption: Contents: advanced Indices and tables ================== * :ref:`genindex` * :ref:`modindex` * :ref:`search`