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.

Image of Timescale

Timescale – the developer's data platform for modern apps, built on PostgreSQL

Timescale Cloud is PostgreSQL optimized for speed, scale, and performance. Over 3 million IoT, AI, crypto, and dev tool apps are powered by Timescale. Try it free today! No credit card required.

Try free

Top comments (0)

Billboard image

The Next Generation Developer Platform

Coherence is the first Platform-as-a-Service you can control. Unlike "black-box" platforms that are opinionated about the infra you can deploy, Coherence is powered by CNC, the open-source IaC framework, which offers limitless customization.

Learn more

👋 Kindness is contagious

Dive into an ocean of knowledge with this thought-provoking post, revered deeply within the supportive DEV Community. Developers of all levels are welcome to join and enhance our collective intelligence.

Saying a simple "thank you" can brighten someone's day. Share your gratitude in the comments below!

On DEV, sharing ideas eases our path and fortifies our community connections. Found this helpful? Sending a quick thanks to the author can be profoundly valued.

Okay