Как отформатировать все числа в таблице в r, используя kable? - PullRequest
0 голосов
/ 11 марта 2019

Code output

Мне нужно уменьшить или упростить числа в этой таблице. Я хочу показывать только до 4 десятичных знаков и, если возможно, только целые числа, если число является целым числом. Как мне это сделать?

library(kableExtra)
x = c(1, 1, 1, 1, 1, 1, 1, 1, 1)
y = x/2
z = x/3
a = data.frame(x, y, z)
b = t(a)
c = kable(b, "html", align = "c") %>%
  kable_styling(full_width = F)

1 Ответ

0 голосов
/ 11 марта 2019

Используйте функцию format() для преобразования данных в минимальное количество знаков после запятой, необходимое для визуализации данных. Используя код из оригинального поста:

library(knitr)
library(kableExtra)
x = c(1, 1, 1, 1, 1, 1, 1, 1, 1)
y = x/2
z = x/3

a = data.frame(x = format(x,digits=4,nsmall = 0), 
               y = format(y,digits=4,nsmall = 0), 
               z = format(z,digits = 4,nsmall = 0))
b = t(a)
c = kable(b, "html", align = "c") %>%
  kable_styling(full_width = F)

... и вывод:

enter image description here

Включая комментарии Мартина Шмельцера, приведенная ниже версия того же решения выглядит следующим образом.

# tidyverse alternative
library(knitr)
library(kableExtra)
library(dplyr)
x = c(1, 1, 1, 1, 1, 1, 1, 1, 1)
y = x/2
z = x/3
data.frame(x,y,z) %>% 
   mutate_if(is.numeric, format, digits=4,nsmall = 0) %>% t(.) %>% kable(.,"html",align = "c") %>% 
   kable_styling(full_width = F) -> c
...