Logo

dev-resources.site

for different kinds of informations.

Poetry Beginner's Guide, Simplifying Python Dependency Management on Linux

Published at
8/1/2024
Categories
python
productivity
linux
management
Author
Shanu Kumawat
Poetry Beginner's Guide, Simplifying Python Dependency Management on Linux

The Need for Virtual Environments and Reproducibility

Python projects often rely on numerous external libraries and packages. As projects grow and evolve, managing these dependencies can become complex. Two critical aspects of Python development are:

  1. Virtual Environments: Isolated spaces that keep project dependencies separate from system-wide Python installations.

  2. Reproducibility: Ensuring that a project can be easily set up and run consistently across different machines or environments.

Traditional tools like venv and pip have long been used for these purposes, but they often require multiple steps and manual intervention. This is where Poetry comes in, offering a more streamlined and robust solution.

Why Choose Poetry?

Poetry offers several advantages over traditional tools:

  1. Simplified Workflow: Combines dependency management, packaging, and publishing in one tool.

  2. Dependency Resolution: Automatically resolves dependencies and potential conflicts.

  3. Reproducible Builds: Ensures consistent environments across different machines.

  4. Lock File: Generates a lock file for exact version control of all dependencies.

  5. Project Isolation: Creates and manages virtual environments automatically.

  6. Intuitive Commands: Offers a user-friendly CLI for common tasks.

Installing and Setting Up Poetry

curl -sSL https://install.python-poetry.org | python3 -

After installation, add Poetry to your PATH by adding the following line to your shell configuration file (e.g., ~/.bashrc or ~/.zshrc):

export PATH="$HOME/.local/bin:$PATH"

Restart your terminal or run source ~/.bashrc (or the appropriate file) to apply the changes.

Verify the installation by running:

poetry --version

Enable tab completion for Bash, Fish, or Zsh

poetry supports generating completion scripts for Bash, Fish, and Zsh.

Bash

poetry completions bash >> ~/.bash_completion

Fish

poetry completions fish > ~/.config/fish/completions/poetry.fish

Zsh

poetry completions zsh > ~/.zfunc/_poetry

Using Poetry

Creating a New Project

To create a new Python project with Poetry:

poetry new my-project
cd my-project

This creates a new directory with a basic project structure, including a pyproject.toml file.

Adding Dependencies

To add a new dependency:

poetry add requests

This adds the package to your pyproject.toml file and installs it in the virtual environment.

Managing Dependencies

View installed packages:

poetry show

Update all packages:

poetry update

Remove a package:

poetry remove requests

Running Scripts

Execute Python scripts within the project's virtual environment:

poetry run python your_script.py

Managing the Virtual Environment

Activate the virtual environment:

poetry shell

Deactivate it:

exit

Building and Publishing

Build your project:

poetry build

Publish to PyPI:

poetry publish

Exporting Requirements

Generate a requirements.txt file:

poetry export -f requirements.txt --output requirements.txt

Conclusion

Poetry simplifies Python project management by providing a unified tool for dependency management, virtual environments, and packaging. Its intuitive interface and powerful features make it an excellent choice for Python developers looking to streamline their workflow and ensure project reproducibility.

Featured ones: