kkt is a tool for kaggle kernel management.
- Show the status of the latest version
- Push your script or notebook to the Kaggle Kernels
- Pack and emmbedded your library codes into the generated bootstrap codes
- Create a dataset containing your dependent packages
- Add bootstrap codes into the head of your script or notebook automatically
- Add git tags whose name is corresponding kernel version
- Set environment variable for your kernels
For now, kkt is designed to be used with poetry. So kkt can be installed by the following.
$ poetry add kkt --dev
Please setup your kaggle-api credentials as following this article
Setup this project for digit-recognizer competition. In this configuration, we use script.py. If you want to use notebook, kkt also support it.
$ poetry run kkt init
Appending Kkt section into your pyproject.toml config.
competition: digit
0 digit-recognizer
> 0
slug: kkt-example
code_file [script.py]: script.py
kernel_type [script]: script
is_private [Y/n]: n
enable_gpu [y/N]: n
enable_internet [y/N]: y
Would you like to add dataset sources? [y/N]: n
enable_git_tag [y/N]: n
kkt_example provides random choice solver for digit-recognizer competition.
$ tree
.
├── kkt_example
│ └── __init__.py
├── poetry.lock
├── pyproject.toml
└── script.py
1 directory, 4 files
init.py
from pathlib import Path
import random
import pandas as pd
def choice():
return random.randint(0, 9)
def load_sample_submission():
path = Path("..") / "input" / "digit-recognizer" / "sample_submission.csv"
return pd.read_csv(path, index_col="ImageId")
script.py
import kkt_example
submission = kkt_example.load_sample_submission()
for _, row in submission.iterrows():
row["Label"] = kkt_example.choice()
submission.to_csv("submission.csv")
pyproject.toml
[tool.poetry]
name = "kkt-example"
version = "0.1.0"
description = ""
authors = ["Masahiro Wada <argon.argon.argon@gmail.com>"]
[tool.poetry.dependencies]
python = "^3.7"
pandas = "^1.0.0"
[tool.poetry.dev-dependencies]
kkt = "^0.3.1"
[tool.kkt]
enable_git_tag = false
[tool.kkt.meta_data]
code_file = "script.py"
competition = "digit-recognizer"
competition_sources = ["digit-recognizer"]
dataset_sources = []
enable_gpu = false
enable_internet = true
is_private = false
kernel_type = "script"
slug = "kkt-example"
[build-system]
requires = ["poetry>=0.12"]
build-backend = "poetry.masonry.api"
If you want run script.py in local environmet, please run the following.
$ poetry run python script.py
$ head submission.csv
ImageId,Label
1,1
2,1
3,0
4,2
5,4
6,8
7,5
8,3
9,2
In this example, there aren't extra required packages. So kkt install
displays the following. And this step is not mandatory.
$ poetry run kkt install
ref: /ar90ngas/kkt-example-install
url: https://www.kaggle.com/ar90ngas/kkt-example-install
version: 1
Pushing install kernel successed.
Wait for install kernel completion...
Wait for install kernel completion...
Wait for install kernel completion...
Extra required packages are nothing.
But in the little complicated project such as mnist_efficientnet example, kkt install
displays the following. This means that a new dataset whose slug is ar90ngas/mnist-efficientnet-requirements
is created. And it contains an extra package which is required by this example. And this package will be installed automatically in the bootstrap code.
$ poetry run kkt install
ref: /ar90ngas/mnist-efficientnet-install
url: https://www.kaggle.com/ar90ngas/mnist-efficientnet-install
version: 1
Pushing install kernel successed.
Wait for install kernel completion...
Wait for install kernel completion...
Wait for install kernel completion...
Output file downloaded to /tmp/tmpq6m9iq9p/timm-0.1.30-py3-none-any.whl
Starting upload for file timm-0.1.30-py3-none-any.whl
100%|█████████████████████████████████████████████████████████| 203k/203k [00:03<00:00, 53.7kB/s]
Upload successful: timm-0.1.30-py3-none-any.whl (203KB)
ref: ar90ngas/mnist-efficientnet-requirements
url: https://www.kaggle.com/ar90ngas/mnist-efficientnet-requirements
$ poetry run kkt push
ref: /ar90ngas/kkt-example
url: https://www.kaggle.com/ar90ngas/kkt-example
version: 1
Please visit the result.
$ poetry run kkt status
status: complete
Please see examples
This software is released under the Apache License, see LICENSE.