https://github.com/heroku/buildpacks-python
Heroku's Cloud Native Buildpack for Python applications.
https://github.com/heroku/buildpacks-python
cloud-native-buildpacks heroku heroku-languages python
Last synced: 6 days ago
JSON representation
Heroku's Cloud Native Buildpack for Python applications.
- Host: GitHub
- URL: https://github.com/heroku/buildpacks-python
- Owner: heroku
- License: bsd-3-clause
- Created: 2021-04-23T12:46:35.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2025-07-03T12:25:13.000Z (6 months ago)
- Last Synced: 2025-07-03T13:28:27.473Z (6 months ago)
- Topics: cloud-native-buildpacks, heroku, heroku-languages, python
- Language: Rust
- Homepage:
- Size: 670 KB
- Stars: 30
- Watchers: 40
- Forks: 3
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: .github/CODEOWNERS
- Security: SECURITY.md
Awesome Lists containing this project
README
# Heroku Cloud Native Buildpack: Python
[![Cloud Native Buildpacks Registry: heroku/python][registry-badge]][registry-url]
[![CI on Github Actions: heroku/python][ci-badge]][ci-url]
![Heroku Cloud Native Buildpack: heroku/python][cnb-banner]
`heroku/python` is the [Heroku Cloud Native Buildpack][heroku-buildpacks]
for Python applications. It builds Python application source code into application images with
minimal configuration.
> [!IMPORTANT]
> This is a [Cloud Native Buildpack][cnb], and is a component of the [Heroku Cloud Native Buildpacks][heroku-buildpacks] project. If you are instead looking for the Heroku Classic Buildpack for Python, you may find it [here][classic-buildpack].
## Usage
> [!NOTE]
> Before getting started, ensure you have the `pack` CLI installed. Installation instructions are available [here][pack-install].
To build a Python application codebase into a production image:
```bash
$ cd ~/workdir/sample-python-app
$ pack build sample-app --builder heroku/builder:24
```
Then run the image:
```bash
docker run --rm -it -e "PORT=8080" -p 8080:8080 sample-app
```
## Application Requirements
A `requirements.txt`, `poetry.lock` or `uv.lock` file must be present in the root (top-level) directory of your app's source code.
When using the package manager [uv](https://docs.astral.sh/uv/) a `.python-version` file is also required.
## Configuration
### Python Version
If a `.python-version` file isn't found, the buildpack will install the latest version of Python 3.14.
To install a different version, add a `.python-version` file to your app's root directory that declares the version number to use:
```term
$ cat .python-version
3.14
```
## Contributing
Issues and pull requests are welcome. See our [contributing guidelines](./CONTRIBUTING.md) if you would like to help.
[ci-badge]: https://github.com/heroku/buildpacks-python/actions/workflows/ci.yml/badge.svg
[ci-url]: https://github.com/heroku/buildpacks-python/actions/workflows/ci.yml
[cnb]: https://buildpacks.io
[cnb-banner]: https://raw.githubusercontent.com/heroku/buildpacks/refs/heads/main/assets/images/buildpack-banner-python.png
[classic-buildpack]: https://github.com/heroku/heroku-buildpack-python
[heroku-buildpacks]: https://github.com/heroku/buildpacks
[pack-install]: https://buildpacks.io/docs/for-platform-operators/how-to/integrate-ci/pack/
[registry-badge]: https://img.shields.io/badge/dynamic/json?url=https://registry.buildpacks.io/api/v1/buildpacks/heroku/python&label=version&query=$.latest.version&color=DF0A6B&logo=&labelColor=white
[registry-url]: https://registry.buildpacks.io/buildpacks/heroku/python