https://github.com/yonicd/texblocks
WIP: tex table building blocks
https://github.com/yonicd/texblocks
Last synced: about 1 month ago
JSON representation
WIP: tex table building blocks
- Host: GitHub
- URL: https://github.com/yonicd/texblocks
- Owner: yonicd
- License: other
- Created: 2018-09-12T18:28:28.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2020-07-14T13:09:01.000Z (over 4 years ago)
- Last Synced: 2025-01-03T10:51:31.425Z (about 2 months ago)
- Language: R
- Homepage: https://yonicd.github.io/texblocks/
- Size: 2.1 MB
- Stars: 12
- Watchers: 10
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.Rmd
- License: LICENSE
Awesome Lists containing this project
- jimsghstars - yonicd/texblocks - WIP: tex table building blocks (R)
README
---
output: github_document
always_allow_html: yes
---```{r, echo = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>"
)
```[data:image/s3,"s3://crabby-images/00ba2/00ba28b940a564c658bbc91eb142b7dd41bcf785" alt="Travis-CI Build Status"](https://travis-ci.org/metrumresearchgroup/texblocks)
[data:image/s3,"s3://crabby-images/0b711/0b711680a4a39ab794fb1b7a0e4b33d1b7df9604" alt="stability-experimental"]()
[data:image/s3,"s3://crabby-images/f7346/f7346a116ba65e2e1714013bbd80fdadf558cc41" alt="Covrpage Summary"](http://tinyurl.com/y7xnwx67)# texblocks
Lets be frank, it is not fun to create TeX tables from scratch.
data:image/s3,"s3://crabby-images/0f8cd/0f8cd8068cef9ee9554197111ebde69d3d5f6121" alt=""
In `R` there are a few ways to get around this task by converting a data.frame into latex tables via [huxtable](https://github.com/hughjonesd/huxtable), [pixiedust](https://github.com/nutterb/pixiedust) and [knitr](https://github.com/yihui/knitr).
But many times you either don't have or don't want to go through a data.frame to get to your table. `{texblocks}` is an attempt to create a natural language with simple operators to quickly create reproducible TeX tables.
## Idea
Assemble LaTeX tabular environments using simple operations.
This would enable us to create any table layout with a consistent user API.
## Proposed Syntax
For a rendered vingette see [basics](https://metrumresearchgroup.github.io/texblocks/articles/basics.html)
Defining a new class of R element `tb` that is the basic structure of the language.
### Joining elements
Let `t1` and `t2` be two objects of class tb.
| | |
|:--:|:--:|
| `t1 + t2` |`r '\u2b1b'` `r '\u2b1b'`|| | |
|:--:|:--:|
||`r '\u2b1b'`|
|`t1 / t2`||
||`r '\u2b1b'`|Using this language creating a table can be broken down to cell level
`t1 =(``r '\u2b1b'`` + ``r '\u2b1b'`` + ``r '\u2b1b'``) / (``r '\u2b1b'`` + ``r '\u2b1b'`` + ``r '\u2b1b'``)`
would be translated to
```
1 & 2 & 3 \\
4 & 5 & 6
```making their combination a natural extension
`t1 + t1`
would translate to
```
1 & 2 & 3 & 1 & 2 & 3 \\
4 & 5 & 6 & 1 & 2 & 3
```### Recasting
Converting to `tb` class
- [numeric](https://metrumresearchgroup.github.io/texblocks/articles/basics.html#single-blocks)
- [character](https://metrumresearchgroup.github.io/texblocks/articles/basics.html#single-blocks)
- [matrix](https://metrumresearchgroup.github.io/texblocks/articles/basics.html#matrix)
- [sparse matrix](https://metrumresearchgroup.github.io/texblocks/articles/basics.html#sparse-matrix)
- [data.frame/tibble](https://metrumresearchgroup.github.io/texblocks/articles/basics.html#data-frame)
texblocks can also be converted back into [`tibbles`](https://metrumresearchgroup.github.io/texblocks/articles/basics.html#as-data-frame) and matrices for further data manipulation.### Vectorizing
texblocks can also be [replicated](https://metrumresearchgroup.github.io/texblocks/articles/basics.html#replicate) and used as a list with `purrr` verbs and base R [`*apply`](https://metrumresearchgroup.github.io/texblocks/articles/basics.html#list) functions.
### Mutations & Aesthetics
For a rendered vingette see [aesthetics](https://metrumresearchgroup.github.io/texblocks/articles/aesthetics.html)
- [multirow/multicolumn](https://metrumresearchgroup.github.io/texblocks/articles/aesthetics.html#multicolmultirow)
- [hline](https://metrumresearchgroup.github.io/texblocks/articles/aesthetics.html#hline)
- [cline](https://metrumresearchgroup.github.io/texblocks/articles/aesthetics.html#cline)
### TODOA set of elements can be defined to control the table and cell level attributes, eg
- font: colour, size, face
- background colour