DEV Community

John  Ajera
John Ajera

Posted on

Getting Started with Python: Creating a Hello World Project Using Poetry

Introduction

Poetry is a powerful dependency management and packaging tool for Python. It simplifies project creation, dependency installation, and environment isolation. In this tutorial, we'll walk through the steps to create and initialize a "Hello, World!" Python project using Poetry. For a practical example, you can refer to the actual code in this GitHub repository: jdevto/python-poetry-hello. 🎉

Prerequisites

Before we start, make sure you have the following installed on your system:

  1. Python (version 3.7 or later)
  2. Poetry (follow the official installation guide)

You can verify your installations by running:

python --version
poetry --version
Enter fullscreen mode Exit fullscreen mode

Step 1: Create a New Project

Start by creating a new directory for your project. Navigate to the directory where you want to store your project and run:

poetry new hello-world
Enter fullscreen mode Exit fullscreen mode

This command creates a new folder named hello-world with the following structure:

hello-world/
├── README.rst
├── hello_world
│   └── __init__.py
├── pyproject.toml
└── tests
    ├── __init__.py
    └── test_hello_world.py
Enter fullscreen mode Exit fullscreen mode

Key Components

  • hello_world/: Contains your Python package.
  • pyproject.toml: Defines your project dependencies and metadata.
  • tests/: Directory for your test cases.

Step 2: Add a "Hello, World!" Script

Navigate to the hello_world directory:

cd hello-world/hello_world
Enter fullscreen mode Exit fullscreen mode

Edit the __init__.py file or create a new file, main.py:

# hello_world/main.py
def main():
    print("Hello, World!")

if __name__ == "__main__":
    main()
Enter fullscreen mode Exit fullscreen mode

Step 3: Update pyproject.toml

Ensure the pyproject.toml file includes an entry point so you can run the script as a command. Add the following under the [tool.poetry.scripts] section:

[tool.poetry.scripts]
hello-world = "hello_world.main:main"

[tool.poetry.dependencies]
python = ">=3.9"

[tool.poetry.group.dev.dependencies]
pytest = "^6.0.0"
pytest-cov = "^3.0.0"
black = "^22.0.0"
flake8 = "^3.9.0"
mypy = "^0.910"
Enter fullscreen mode Exit fullscreen mode

Step 4: Install Dependencies

Run the following command to install any dependencies and prepare the environment:

poetry install
Enter fullscreen mode Exit fullscreen mode

Step 5: Run Your Script

To test your script, use:

poetry run hello-world
Enter fullscreen mode Exit fullscreen mode

You should see the output:

Hello, World!
Enter fullscreen mode Exit fullscreen mode

Step 6: Adding Tests

To ensure your script works correctly, add a test case in the tests/test_hello_world.py file:

def test_main(capsys):
    from hello_world.main import main

    main()
    captured = capsys.readouterr()
    assert captured.out == "Hello, World!\n"
Enter fullscreen mode Exit fullscreen mode

Run the tests using Poetry:

poetry run pytest
Enter fullscreen mode Exit fullscreen mode

Reminder: Running poetry lock After Changes

After changing the prerequisites or modifying dependencies in the pyproject.toml file (such as adding new dependencies or updating versions), always run poetry lock to regenerate the poetry.lock file and ensure that the correct versions are installed in your environment.

poetry lock
Enter fullscreen mode Exit fullscreen mode

This step ensures that your lock file stays up-to-date with the pyproject.toml configuration and guarantees consistency across your development and production environments.

Conclusion

Congratulations! You've successfully created a "Hello, World!" Python project using Poetry with a working example, visit the GitHub repository: jdevto/python-poetry-hello. This setup provides a solid foundation for building more complex applications while managing dependencies and packaging effortlessly.

Feel free to explore additional features of Poetry, like dependency version constraints, virtual environments, and publishing packages.

Top comments (0)