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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
49fa93f150fd73bf4eee85c0e95cb8737d9705a1445d1c6cb2864f667eaa097a
|
|
| MD5 |
17fb0c5d9036554d1b545fae281c0fb5
|
|
| BLAKE2b-256 |
448d931256af8d217caebf26393c81507e9fae6d84812374e8b8e4d3017a8dbc
|
File details
Details for the file pck_manojbudathoki-0.0.1-py3-none-any.whl.
File metadata
- Download URL: pck_manojbudathoki-0.0.1-py3-none-any.whl
- Upload date:
- Size: 2.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a4570a9ec257232ecb74938dac5e7b7391da5db707db9e87970be503468ecf15
|
|
| MD5 |
e61d5159c3dee64dc1e7c453a5c72ec7
|
|
| BLAKE2b-256 |
786c8579672ef72a15bc668a744f8293dca38aeb0e0d29bd9f787d6c3a840b60
|