Getting started with Kili CLI
What is Kili CLI
Kili CLI has been designed to run key actions on your projects with powerful commands. For the actions it supports, the CLI offers a more compact way to manage your projects than the Python SDK. Note that the Python SDK offers more options and may still be used for more complex project management tasks.
Authentication
- Create and copy a Kili API key
- Add the
KILI_API_KEY
variable in your bash environment (or in the settings of your favorite IDE) by pasting the API key value that you copied earlier:
export KILI_API_KEY='<you api key value here>'
Info
While launching commands, you can also provide you API key through the --api-key
option. If you set your api key in the KILI_API_KEY
environment variable and provide it once again through the --api-key
option, Kili CLI will use the api key value provided in command options.
Usage
The main command is kili
. It currently has only one subcommand project
that entails all the commands for project management :
kili project [COMMAND]
Workflow example
Let's take an example where you want to start a project from scratch
You can download ressources to run this example here.
Once in the current directory where all files are stored, you can run the following commands:
Create a project
To create an IMAGE project:
kili project create \
json_interface.json \
--title "Quality inspection" \
--input-type IMAGE \
--description "Steel defects on production line"
Ouput:
ID URL
<project_id> https://cloud.kili-technology.com/label/projects/<project_id>/
List your projects
kili project list --max 10
Ouput:
TITLE ID PROGRESS DESCRIPTION
Quality inspection <project_id> 0.0% Steel defects on production line...
Recover your project ID
export project_id=$(kili project list \
| grep -m1 "Quality inspection" \
| awk '{print $3}')
Add a member to your project
kili project member add \
<email_adress> \
--project-id $project_id \
--role REVIEWER
Ouput:
1 member(s) have been successfully added to project: <project_id>
List the project's members
kili project member list --project-id $project_id
Ouput:
ROLE NAME EMAIL ID ORGANIZATION
ADMIN <your_name> <your_email> <your_member_id> <your_organization>
REVIEWER <reviewer_name> <email_adress> <member_id> <your_organization>
Import data to your project
To import data, provide a list of files or folders (you can also procide a csv file external_id and file's paths)
kili project import \
assets \
--project-id $project_id
Ouput:
40 files have been successfully imported
Import labels to your project
To import labels, provide a list of files or folders (you can also procide a csv file external_id and label's paths).
Label's files are json with the json_response to upload
CSV file template
external_id;json_response_path
asset1; ./labels/label_asset1.json
asset2;./labels/label_asset2.json
kili project label \
--project-id $project_id \
--from-csv labels.csv
Outputs:
10 labels have been successfully imported
If you have run a pre-annotation model, you can also import labels as predictions. These labels will be seen as pre-annotation in the labeling interface.
kili project label \
--project-id $project_id \
--from-csv labels.csv \
--prediction \
--model-name YOLO-run-3
Outputs:
10 labels have been successfully imported
Get metrics of your project
kili project describe $project_id
Ouput:
Title Quality inspection
Description Steel defects on production line
Dataset KPIs
------------
Total number of assets 40
Number of remaining assets 10
Skipped assets 0
Progress 25.0%
Quality KPIs
------------
Project consensus N/A
Project honeypot N/A
Number of reviewed assets 0
Number of open issues 0
Number of solved issues 0
Number of open questions 0
Number of solved questions 0