Learn R Programming

pillar

pillar provides tools for styling columns of data, artfully using colour and unicode characters to guide the eye.

Installation

# pillar is installed if you install the tidyverse package:
install.packages("tidyverse")

# Alternatively, install just pillar:
install.packages("pillar")

Usage

pillar is a developer-facing package that is not designed for end-users. It powers the print() and format() methods for tibbles. It also and defines generics and helpers that are useful for package authors who create custom vector classes (see https://github.com/krlmlr/awesome-vctrs#readme for examples) or custom table classes (like dbplyr or sf).

library(pillar)

x <- 123456789 * (10^c(-3, -5, NA, -8, -10))
pillar(x)
#> <pillar>
#>       <dbl>
#> 123457.    
#>   1235.    
#>     NA     
#>      1.23  
#>      0.0123

tbl_format_setup(tibble::tibble(x))
#> <pillar_tbl_format_setup>
#> <tbl_format_header(setup)>
#> # A tibble: 5 × 1
#> <tbl_format_body(setup)>
#>             x
#>         <dbl>
#> 1 123457.    
#> 2   1235.    
#> 3     NA     
#> 4      1.23  
#> 5      0.0123
#> <tbl_format_footer(setup)>

Custom vector classes

The primary user of this package is tibble, which lets pillar do all the formatting work. Packages that implement a data type to be used in a tibble column can customize the display by implementing a pillar_shaft() method.

library(pillar)

percent <- vctrs::new_vctr(9:11 * 0.01, class = "percent")

pillar_shaft.percent <- function(x, ...) {
  fmt <- format(vctrs::vec_data(x) * 100)
  new_pillar_shaft_simple(paste0(fmt, " ", style_subtle("%")), align = "right")
}

pillar(percent)
#> <pillar>
#> <percent>
#>       9 %
#>      10 %
#>      11 %

See vignette("pillar", package = "vctrs") for details.

Custom table classes

pillar provides various extension points for customizing how a tibble-like class is printed.

tbl <- vctrs::new_data_frame(list(a = 1:3), class = c("my_tbl", "tbl"))

tbl_sum.my_tbl <- function(x, ...) {
  c("Hello" = "world!")
}

tbl
#> # Hello: world!
#>       a
#>   <int>
#> 1     1
#> 2     2
#> 3     3

See vignette("extending", package = "pillar") for a walkthrough of the options.


Code of Conduct

Please note that the pillar project is released with a Contributor Code of Conduct. By contributing to this project, you agree to abide by its terms.

Copy Link

Version

Install

install.packages('pillar')

Monthly Downloads

1,033,355

Version

1.10.1

License

MIT + file LICENSE

Issues

Pull Requests

Stars

Forks

Maintainer

Kirill M<c3><bc>ller

Last Published

January 7th, 2025

Functions in pillar (1.10.1)

tbl_format_body

Format the body of a tibble
new_pillar_title

Prepare a column title for formatting
num

Format a numeric vector in a tibble
pillar-package

pillar: Coloured Formatting for Columns
tbl_format_footer

Format the footer of a tibble
tbl_sum

Provide a succinct summary of an object
tbl_nrow

Number of rows in a tbl object
type_sum

Provide a succinct summary of an object
pillar

Object for formatting a vector suitable for tabular display
tbl_format_header

Format the header of a tibble
tbl_format_setup

Set up formatting
pillar_options

Package options
style_num

Styling helpers
squeeze

Squeeze a colonnade to a fixed width
pillar_shaft

Column data
scale_x_num

Scale that supports formatted numbers
format_glimpse

Format a vector for horizontal printing
ctl_new_pillar_list

Customize the appearance of compound pillars in your tibble subclass
dim_desc

Format dimensions
char

Format a character vector in a tibble
ctl_new_pillar

Customize the appearance of simple pillars in your tibble subclass
align

Alignment helper
glimpse

Get a glimpse of your data
new_pillar_type

Prepare a column type for formatting
format_type_sum

Format a type summary
new_pillar_component

Components of a pillar
new_pillar_shaft

Constructor for column data
new_pillar

Construct a custom pillar object
new_ornament

Helper to define the contents of a pillar
colonnade

Format multiple vectors in a tabular display
extra_cols

Retrieve information about columns that didn't fit the available width
new_tbl_format_setup

Construct a setup object for formatting
format_tbl

Formatting of tbl objects
deprecated

Deprecated functions
get_extent

Calculate display width