Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Kaggle/kaggle-api
Official Kaggle API
https://github.com/Kaggle/kaggle-api
Last synced: 3 months ago
JSON representation
Official Kaggle API
- Host: GitHub
- URL: https://github.com/Kaggle/kaggle-api
- Owner: Kaggle
- License: apache-2.0
- Created: 2018-01-25T03:02:39.000Z (almost 7 years ago)
- Default Branch: main
- Last Pushed: 2024-05-21T08:03:20.000Z (8 months ago)
- Last Synced: 2024-05-22T04:32:29.779Z (8 months ago)
- Language: Python
- Homepage:
- Size: 12.7 MB
- Stars: 5,948
- Watchers: 198
- Forks: 1,050
- Open Issues: 151
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
- awesome-python-machine-learning-resources - GitHub - 57% open · ⏱️ 15.03.2021): (工作流程和实验跟踪)
- jimsghstars - Kaggle/kaggle-api - Official Kaggle API (Python)
- StarryDivineSky - Kaggle/kaggle-api
README
# Kaggle API
Official API for https://www.kaggle.com, accessible using a command line tool implemented in Python 3.
[User documentation](docs/README.md)
## Installation
Ensure you have Python 3 and the package manager `pip` installed.
Run the following command to access the Kaggle API using the command line:
```sh
pip install kaggle
```## Development
### Kaggle Internal
Obviously, this depends on Kaggle services. When you're extending the API and modifying
or adding to those services, you should be working in your Kaggle mid-tier development
environment. You'll run Kaggle locally, in the container, and test the Python code by
running it in the container so it can connect to your local testing environment.
However, do not try to create a release from within the container. The code formatter
(`yapf3`) changes much more than intended.Also, run the following command to get `autogen.sh` installed:
```bash
rm -rf /tmp/autogen && mkdir -p /tmp/autogen && unzip -qo /tmp/autogen.zip -d /tmp/autogen &&
mv /tmp/autogen/autogen-*/* /tmp/autogen && rm -rf /tmp/autogen/autogen-* &&
sudo chmod a+rx /tmp/autogen/autogen.sh
```### Prerequisites
We use [hatch](https://hatch.pypa.io) to manage this project.
Follow these [instructions](https://hatch.pypa.io/latest/install/) to install it.
If you are working in a managed environment, you may want to use `pipx`. If it isn't already installed
try `sudo apt install pipx`. Then you should be able to proceed with `pipx install hatch`.### Dependencies
```sh
hatch run install-deps
```### Compile
```sh
hatch run compile
```The compiled files are generated in the `kaggle/` directory from the `src/` directory.
All the changes must be done in the `src/` directory.
### Run
You can also run the code in python directly:
```sh
hatch run python
``````python
import kaggle
from kaggle.api.kaggle_api_extended import KaggleApi
api = KaggleApi()
api.authenticate()
api.model_list_cli()Next Page Token = [...]
[...]```
Or in a single command:
```sh
hatch run python -c "import kaggle; from kaggle.api.kaggle_api_extended import KaggleApi; api = KaggleApi(); api.authenticate(); api.model_list_cli()"
```### Example
Let's change the `model_list_cli` method in the source file:
```sh
❯ git diff src/kaggle/api/kaggle_api_extended.py
[...]
+ print('hello Kaggle CLI update')^M
models = self.model_list(sort_by, search, owner, page_size, page_token)
[...]❯ hatch run compile
[...]❯ hatch run python -c "import kaggle; from kaggle.api.kaggle_api_extended import KaggleApi; api = KaggleApi(); api.authenticate(); api.model_list_cli()"
hello Kaggle CLI update
Next Page Token = [...]
```### Integration Tests
To run integration tests on your local machine, you need to set up your Kaggle API credentials. You can do this in one of these two ways described [this doc](docs/README.md). Refer to the sections:
- Using environment variables
- Using credentials fileAfter setting up your credentials by any of these methods, you can run the integration tests as follows:
```sh
# Run all tests
hatch run integration-test
```## License
The Kaggle API is released under the [Apache 2.0 license](LICENSE).