Skip to content

Applying color gradients to columns

Numeric trends in larger tables can quickly become difficult to see. Adding color to reveal these trends can be one way to make reading complex tables a little easier.

The data

Clean gradients in real data can be hard to come by. Excuse the contrived nature of the data below, but I really want to make a rainbow gradient!

julia
using StyledTables, DataFrames, Colors

df = DataFrame(id = 1:8, score = rand(8))
8×2 DataFrame
Rowidscore
Int64Float64
110.318336
220.166078
330.561906
440.846398
550.113528
660.225248
770.0489718
880.558733

So far so boring.

The gradient we'll be applying is the following:

julia
colors = range(HSV(0,1,1), stop = HSV(-360,1,1), length = nrow(df))

Step 1: Styling function

The function below is more general than what would be required for the specific example here. In our case, it would be possible to simply use the id variable to index into colors.

julia
function apply_gradient(x, xmax; colors)
    color = colors[round(Int, (x / xmax) * length(colors))]
    return (; color)
end
apply_gradient (generic function with 1 method)

Step 2: Apply styling

julia
tbl = StyledTable(df)
style!(x -> apply_gradient(x, maximum(df.id); colors), tbl, :id)
render(tbl)
id score
1 0.318
2 0.166
3 0.562
4 0.846
5 0.114
6 0.225
7 0.049
8 0.559

Step 3: Column labels

@example
cols_label!(tbl, :id => "Student ID", :score => "Score")
render(tbl)