Подтвердить что ты не робот

Создание таблиц с условным форматированием с помощью RMarkdown + knitr

У меня есть кадр данных, и я хочу вывести его в файл HTML через knitr и RMarkdown в виде таблицы с условным форматированием. Пример:

n <- data.frame(x = c(1,1,1,1,1), y = c(0,1,0,1,0))
> n
  x y
1 1 0
2 1 1
3 1 0
4 1 1
5 1 0

Я хочу выделить строки с разными значениями x и y. Таким образом, в этом случае это будут строки 1, 3 и 5. Было бы неплохо, если вывод в HTML файле был бы HTML-таблицей, но при этом не получилось бы и изображения.

4b9b3361

Ответ 1

Я всегда хотел расширить pandoc.table в моем пакете pander с этой функцией, но не смог получить время для этого. Но этот вопрос действительно вдохновляет, возможно, сделает это в ближайшие несколько дней. До тех пор, как насчет:

  • Загрузите пакет:

    library(pander)
    
  • Загрузите свои данные:

    n <- data.frame(x = c(1,1,1,1,1), y = c(0,1,0,1,0))
    
  • Обновите свои строки, которые будут помечены как strong в Pandoc:

    for (i in c(1, 3, 5))
        n[i, ] <- pandoc.strong.return(n[1, ])
    
  • Показать версию вашей таблицы:

    pandoc.table(n)
    pander(n)       # S3 method
    
  • Скрыть уценку, например. HTML с синтаксисом brew:

    Pandoc.brew(text = '<%=n%>', output = tempfile(), convert = 'html')
    

Обновление: Я обновил pander, чтобы принять некоторые новые аргументы, чтобы легко выделить строки/столбцы/ячейки. Хотя я все еще работаю над некоторыми дополнительными вспомогательными функциями, чтобы облегчить этот процесс, здесь приведена быстрая демонстрация, чтобы вы могли увидеть, как это может помочь вашему документообороту:

> pandoc.table(n, emphasize.rows = c(1, 3, 5))

-------
 x   y 
--- ---
*1* *0*

 1   1 

*0* *1*

 1   1 

*1* *0*
-------

> pandoc.table(n, emphasize.strong.cells = which(n == 1, arr.ind = TRUE))

-----------
  x     y  
----- -----
**1**   0  

**1** **1**

**1**   0  

**1** **1**

**1**   0  
-----------

Обновление: pander получили некоторые вспомогательные функции, чтобы еще проще выделить ячейки в таблицах:

> t <- mtcars[1:3, 1:5]
> emphasize.cols(1)
> emphasize.rows(1)
> pandoc.table(t)

----------------------------------------------------
      &nbsp;         mpg    cyl   disp   hp    drat 
------------------- ------ ----- ------ ----- ------
   **Mazda RX4**     *21*   *6*  *160*  *110* *3.9* 

 **Mazda RX4 Wag**   *21*    6    160    110   3.9  

  **Datsun 710**    *22.8*   4    108    93    3.85 
----------------------------------------------------

Или непосредственно с помощью метода pander:

> emphasize.strong.cells(which(t > 20, arr.ind = TRUE))
> pander(t)

---------------------------------------------------------
      &nbsp;          mpg     cyl   disp     hp     drat 
------------------- -------- ----- ------- ------- ------
   **Mazda RX4**     **21**    6   **160** **110**  3.9  

 **Mazda RX4 Wag**   **21**    6   **160** **110**  3.9  

  **Datsun 710**    **22.8**   4   **108** **93**   3.85 
---------------------------------------------------------

Обратите внимание, что эти новые функции еще не опубликованы в CRAN, но вы можете найти в самой последней версии, размещенной на GitHub.

Ответ 2

Здесь находится решение на основе xtable с пользовательским css. Я думаю, что решение является гибким, поскольку, как только вы его заработаете, вы можете неограниченно настраивать свои html-таблицы, если знаете некоторые трюки css.

Здесь мы идем. Решение состоит из 3 файлов:

  • файл css, где я чередую цвет строки таблицы.

    table {
       max-width: 95%;
       border: 1px solid #ccc;
    }
    
    th {
      background-color: #000000;
     color: #ffffff;
    }
    
    table tr:nth-child(odd) td{
       background-color: #FF0000;
    }
    table tr:nth-child(even) td{
        background-color: #00FFFF;
    }
    
  • файл R script для установки уставки RStudio со следующим содержимым:

    options(rstudio.markdownToHTML = 
          function(inputFile, outputFile) {      
            require(markdown)
            markdownToHTML(inputFile, outputFile, stylesheet='customstyle.css')   
          }
    )
    
  • создайте новую уценку со следующим:

    ```{r}
     source('initmd.R')
    ```
    
    
    ```{r,results='asis'}
    library(xtable)
    n <- data.frame(x = c(1,1,1,1,1), y = c(0,1,0,1,0))
    print(xtable(n),type='html')
    ```
    

окончательно преобразуйте markdwon в html с помощью кнопки knit HTML, и вы должны получить что-то вроде этого:

enter image description here