(ns tc-md-example
(:require
[nextjournal.clerk :as clerk]
[tablecloth.api :as tc]))

Markdown Tables

You can create markdown tables by concating some strings together like so.

The syntax for markdown tables is here.

(clerk/md
(str
"| Foo | Bar | Baz |\n"
"| :--- | :---: | ---: |\n"
"| foo | bar | 12.00 |\n"
"| quz | quux | 1.0 |\n"))
FooBarBaz
foobar12.00
quzquux1.0

This means you can also get data out of a tablecloth/tech.ml dataset and format it too.

(defn md-row [v]
(str "| " (apply str (interpose " | " v)) " |\n"))
#object[tc_md_example$md_row 0x4bb8e9ec "
tc_md_example$md_row@4bb8e9ec"
]
(defn md-table [{:keys [columns alignment-spec data]}]
(clerk/md
(apply
str
(into [(md-row columns)
(md-row alignment-spec)]
(comp
(map
(fn [row]
((apply juxt
(map (fn [column] (fn [m] (m column))) columns))
row)))
(map md-row))
(tc/rows data :as-maps)))))
#object[tc_md_example$md_table 0x7a89261c "
tc_md_example$md_table@7a89261c"
]
(md-table {:columns ["Foo" "Bar" "Baz"]
:alignment-spec [":---" ":---:" "---:"]
:data (tc/dataset {"Foo" ["foo0" "foo1" "foo2"]
"Bar" ["bar0" "bar1" "bar2"]
"Baz" [12.0 1.00 1.01]})})
FooBarBaz
foo0bar012.0
foo1bar11.0
foo2bar21.01