Skip to main content

A small example package

Project description

Overview

The goal of this activity is to introduce you to python's packaging system called PyPi (Python Package Index). PyPi maintains a directory service for contributed packages that is accessible by pip whenever the tool is used to install a new package.

Part 1

Begin by creating a folder for your package under src. Because the name of your package has to be unique, name it as "<your_name>lib", replacing <your_name> accordingly (don't use spaces).

src/<your_name>lib

Next, create the following file structure for your package.

src
|__pck_<your_name>
   |__ __init__.py
   |__ mod.py
|__test.py
|__README.md
|__pyproject.toml

Leave init.py blank. init.py is required to import the directory as a package, and can be left empty. Next, add the following code in mod.py, which will be the single module in your package.

def add_one(number):
    return number + 1

Add the following code in test.py. It will not be a proper test, just a validation that the package can be properly imported and used.

from <your_name>lib import mod

print(mod.add_one(5))

Make sure you are able to run test.py from src.

After the validation, add the following in pyproject.toml, making sure to update <your_name>. TOML stands for Tom's Obvious Minimal Language and it is a configuration format.

[build-system]
requires = ["hatchling"]
build-backend = "hatchling.build"

[project]
name = "<your_name>lib"
version = "0.0.1"
authors = [
  { name="Example Author", email="author@example.com" },
]
description = "A small example package"
readme = "README.md"
requires-python = ">=3.7"
classifiers = [
    "Programming Language :: Python :: 3",
    "License :: OSI Approved :: MIT License",
    "Operating System :: OS Independent",
]

[project.urls]
"Homepage" = "https://github.com/pypa/sampleproject"
"Bug Tracker" = "https://github.com/pypa/sampleproject/issues"

Write something about your project in README.md (it cannot be left blank).

Next, try to build your project using:

python3 -m build src

If you get an error saying "No module named build" it means that you need to install build using pip3. After a successful build, a dist folder will be created (under src).

Part 2

Next, it is time to publish your package so others can use. You need an account in https://pypi.org/. Then, go to https://pypi.org/manage/account/ and scroll down so you can click on the "Add API token" button. Give your token a name and select "Entire account (all projects)" as the scope. Copy the token and use it to run the following:

python3 -m twine upload -u __token__ -p <replace with your token> src/dist/*

You can repeat this process multiple times if needed. For example, you may want to update your package. To do that, update the version of your package in pyproject.toml. Next, remove the dist folder and rebuild. Finally, upload the new version.

To test the installation and use of your package from PyPi, create a virtual environment and run test.py.

More Information

PyPi user guide is available here.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pck_manojbudathoki-0.0.1.tar.gz (2.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pck_manojbudathoki-0.0.1-py3-none-any.whl (2.8 kB view details)

Uploaded Python 3

File details

Details for the file pck_manojbudathoki-0.0.1.tar.gz.

File metadata

  • Download URL: pck_manojbudathoki-0.0.1.tar.gz
  • Upload date:
  • Size: 2.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.6

File hashes

Hashes for pck_manojbudathoki-0.0.1.tar.gz
Algorithm Hash digest
SHA256 49fa93f150fd73bf4eee85c0e95cb8737d9705a1445d1c6cb2864f667eaa097a
MD5 17fb0c5d9036554d1b545fae281c0fb5
BLAKE2b-256 448d931256af8d217caebf26393c81507e9fae6d84812374e8b8e4d3017a8dbc

See more details on using hashes here.

File details

Details for the file pck_manojbudathoki-0.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for pck_manojbudathoki-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a4570a9ec257232ecb74938dac5e7b7391da5db707db9e87970be503468ecf15
MD5 e61d5159c3dee64dc1e7c453a5c72ec7
BLAKE2b-256 786c8579672ef72a15bc668a744f8293dca38aeb0e0d29bd9f787d6c3a840b60

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page