Function piping with the focus on making general data processing boilerplate-free.

DataPipes.jl is extensively tested with full coverage and more test lines than the actual code.

Questions other than direct bug reports are best asked in the .


There are multiple implementation of the piping concept in Julia: 1, 2, 3, 4, maybe even more. DataPipes design is focused on usual data processing and analysis tasks. What makes DataPipes distinct from other packages is that it ticks all these points:

✅ Gets rid of basically all boilerplate for common data processing functions:

@p tbl |> filter(_.a > 5) |> map(_.b + _.c)

✅ Can be inserted in as a step of a vanilla Julia pipeline without modifying the latter:

tbl |> sum  # before
tbl |> @f(map(_ ^ 2) |> filter(_ > 5)) |> sum  # after

✅ Can define a function transforming the data instead of immediately applying it

func = @f map(_ ^ 2) |> filter(_ > 5) |> sum  # define func
func(tbl)  # apply it

✅ Supports easily exporting the result of an intermediate pipeline step

@p let
    @export tbl_filt = filter(_.a > 5)  # export a single intermediate result
    map(_.b + _.c)

@p begin  # use begin instead of let to make all intermediate results available afterwards
    tbl_filt = filter(_.a > 5)
    map(_.b + _.c)

# tbl_filt is available here

✅ Provides no-boilerplate nesting

@p let
	"a=1 b=2 c=3"
	map() do __  # `__` turns the inner function into a pipeline
		split(__, '=')
		Symbol(__[1]) => parse(Int, __[2])
end  # == (a = 1, b = 2, c = 3)

As demonstrated, DataPipes tries to minimally modify regular Julia syntax and stays fully composable both with other instruments (vanilla pipelines) and with itself (nested pipes).


Those design decisions make DataPipes convenient for both working with flat tabular data, and for processing nested structures. An example of the former:

@p begin
    filter(!any(ismissing, _))
    filter( > 6)

(adapted from the Chain.jl README; all DataFrames-specific operations replaced with general functions)

See the Pluto notebook for more examples and more extensive DataPipes syntax description.