renovate/docs/usage/python.md
HonkingGoose 8560b5d657
docs: remove punctuation from end of (un)ordered lists (#7669)
* fix bad indentation

* remove punctuation from end of (un)ordered lists
2020-11-06 12:00:57 +01:00

109 lines
3.8 KiB
Markdown

---
title: Python Package Manager Support
description: Python/pip dependencies support in Renovate
---
# Python Package Manager Support
Renovate supports the following Python package managers:
- `pip` (e.g. `requirements.txt`, `requirements.pip`) files
- `pipenv` (e.g. `Pipfile`)
- `setup.py`
## Versioning Support
The [PEP440](https://www.python.org/dev/peps/pep-0440/) versioning scheme has been rewritten for JavaScript for the purposes of use in this project is published as [@renovatebot/pep440](https://github.com/renovatebot/pep440).
It supports both pinned versions as well as ranges. Legacy versions (`===` prefix) are ignored.
## How It Works
1. Renovate will search each repository for any package files it finds
2. Existing dependencies will be extracted from the file(s)
3. Renovate will look up the latest version on [PyPI](https://pypi.org/) to determine if any upgrades are available
4. If the source package includes a GitHub URL as its source, and has either a "changelog" file or uses GitHub releases, then Release Notes for each version will be embedded in the generated PR
## Enabling Beta
Both `pipenv` and `setup.py` are classified a "beta", so they are not enabled by default.
To enable them, you need to add configuration like the following to your `renovate.json` file:
```json
{
"pipenv": {
"enabled": true
}
}
```
Note: if you _only_ have these package files and no other package files (like `package.json`, `Dockerfile`, etc) then Renovate won't detect them and you won't get an onboarding PR.
In that case you need to add Renovate configuration manually to skip the onboarding step.
## Alternative file names
The default file matching regex for `requirements.txt` aims to pick up the most popular conventions for file naming, but it's possible that some get missed.
If you have a specific file or file pattern you want to get found by Renovate, then you can do this by adding a new pattern under the `fileMatch` field of `pip_requirements`.
e.g. you could add this to your config:
```json
"pip_requirements": {
"fileMatch": ["my/specifically-named.file", "\.requirements$"]
}
```
## Alternate registries
Renovate will default to performing all lookups on pypi.org, but it also supports alternative index URLs.
There are two ways to achieve this:
#### index-url in `requirements.txt`
The index URL can be specified in the first line of the file.
For example:
```
--index-url http://example.com/private-pypi/
some-package==0.3.1
some-other-package==1.0.0
```
#### Sources in `Pipfile`
Renovate will detect any custom-configured sources in `Pipfile` and use them.
#### Specify URL in configuration
The configuration option `registryUrls` can be used to configure an alternate index URL.
Example:
```json
"python": {
"registryUrls": ["http://example.com/private-pypi/"]
}
```
Note: an index-url found in the `requirements.txt` will take precedent over a registryUrl configured like the above.
To override the URL found in `requirements.txt`, you need to configure it in `packageRules`, as they are applied _after_ package file extraction.
## Disabling Python Support
The most direct way to disable all Python support in Renovate is like this:
```json
"python": {
"enabled": false
}
```
Alternatively, maybe you only want one package manager, such as `npm`.
In that case this would enable _only_ `npm`:
```json
"enabledManagers": ["npm"]
```
## Future work
Feature requests are open for conda support and additional file types (e.g. `setup.cfg`).
You can locate these issues by filtering on the [#python](https://github.com/renovatebot/renovate/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc+label%3A%23python) hashtag in the repository.
Please +1 and/or add a comment to each issue that would benefit you so that we can gauge the popularity/importance of each.