A wrapper of luigi. This make it easy to define tasks.
Project description
gokart
A wrapper of the data pipeline library "luigi".
Getting Started
Run pip install gokart
to install the latest version from PyPI. Documentation for the latest release is hosted on readthedocs.
How to Use
Please use gokart.TaskOnKart instead of luigi.Task to define your tasks.
Basic Task with gokart.TaskOnKart
import gokart
class BasicTask(gokart.TaskOnKart):
def requires(self):
return TaskA()
def output(self):
# please use TaskOnKart.make_target to make Target.
return self.make_target('basic_task.csv')
def run(self):
# load data which TaskA output
texts = self.load()
# do something with texts, and make results.
# save results with the file path {self.workspace_directory}/basic_task_{unique_id}.csv
self.dump(results)
Details of base functions
Make Target with TaskOnKart
TaskOnKart.make_target
judge Target
type by the passed path extension. The following extensions are supported.
- pkl
- txt
- csv
- tsv
- gz
- json
- xml
Make Target for models which generate multiple files in saving.
TaskOnKart.make_model_target
and TaskOnKart.dump
are designed to save and load models like gensim.model.Word2vec.
class TrainWord2Vec(TaskOnKart):
def output(self):
# please use 'zip'.
return self.make_model_target(
'model.zip',
save_function=gensim.model.Word2Vec.save,
load_function=gensim.model.Word2Vec.load)
def run(self):
# make word2vec
self.dump(word2vec)
Load input data
Pattern 1: Load input data individually.
def requires(self):
return dict(data=LoadItemData(), model=LoadModel())
def run(self):
# pass a key in the dictionary `self.requires()`
data = self.load('data')
model = self.load('model')
Pattern 2: Load input data at once
def run(self):
input_data = self.load()
"""
The above line is equivalent to the following:
input_data = dict(data=self.load('data'), model=self.load('model'))
"""
Load input data as pd.DataFrame
def requires(self):
return LoadDataFrame()
def run(self):
data = self.load_data_frame(required_columns={'id', 'name'})
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
gokart-0.3.0.tar.gz
(26.5 kB
view details)
File details
Details for the file gokart-0.3.0.tar.gz
.
File metadata
- Download URL: gokart-0.3.0.tar.gz
- Upload date:
- Size: 26.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/3.6.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1194e6ab9f2c042f89167e21071c10191eaeca6bc92005363684f657237ee927 |
|
MD5 | 3858a074285a1385feb1b14e706ee3a6 |
|
BLAKE2b-256 | c837e25b6be0941afd4d13c74da16a252dd3502f8570d5f5cb758f42f0c607c4 |