Clojure data processing framework with parallel computing on larger-than-memory datasets
Unlimited Size
It supports datasets larger than memory.
Various Operations
Although Clojask is designed for larger-than-memory datasets, like NoSQLs, it does not sacrifice common operations on relational dataframes, such as group by, aggregate, join.
Fast
Faster than Dask in most operations, and the larger the dataframe is, the bigger the advantage. Please find the benchmarks here.
All Native Types
All the datatypes used to store data are native Clojure (or Java) types.
From File to File
Integrate IO inside the dataframe. No need to write your own read-in and output functions.
Parallel
Most operations could be executed into multiple threads or even machines. See the principle in Onyx.
Lazy Operations
Most operations will not be executed immediately. Dataframe will intelligently pipeline the operations altogether in computation.
Little Constraints on programming
Except for some aggregations where you need to write customized functions subject to simple templates, operations in Clojask support arbitrary Clojure functions as input
Available on Clojars .
Insert this line into your project.clj
if using Leiningen.
[com.github.clojure-finance/clojask "2.0.2"]
Insert this line into your deps.edn
if using CLI.
com.github.clojure-finance/clojask {:mvn/version "2.0.2"}
Requirements:
Import Clojask
(require '[clojask.dataframe :as ck])
Initialize a dataframe
(def df (ck/dataframe "Employees-example.csv"))
The source file can be found here.
See dataframe
Preview the first few lines of the dataframe
(ck/print-df df)
See print-df
Change the data type of some columns
(ck/set-type df "Salary" "double")
(ck/set-type df "UpdateDate" "date:yyyy/MM/dd")
(ck/print-df df)
See set-type
Add 100 to Bob as NewSalary
(ck/operate df (fn [EmployeeName Salary] (if (= EmployeeName "Bob") (+ Salary 100) Salary)) ["EmployeeName" "Salary"] "NewSalary")
(ck/print-df df)
See operate
Output the resultant dataset to "result.csv" (Use 8 threads)
(ck/compute df 8 "result.csv" :select ["Employee" "EmployeeName" "Department" "NewSalary" "UpdateDate"])
See compute
The detailed documentation for every API can be found here.
A separate repository for some typical usage of Clojask can be found here.
If your question is not answered in existing issues, feel free to create a new one.
Can you improve this documentation? These fine people already did:
Yuchen Liu, awoo424, clojure-finance, Karanveer Singh, c-sungho & Angel WooEdit on GitHub
cljdoc is a website building & hosting documentation for Clojure/Script libraries
× close