4

当我尝试knitr::kable在列名中使用函数“id”字出现打印表时。我怎样才能改变它?

例子:

> x <- structure(c(42.3076923076923, 53.8461538461538, 96.1538461538462,
                   2.56410256410256, 1.28205128205128, 3.84615384615385,
                   44.8717948717949, 55.1282051282051, 100),
                 .Dim = c(3L, 3L),
                 .Dimnames = structure(list(Condition1 = c("Yes", "No", "Sum"),
                                            Condition2 = c("Yes", "No", "Sum")),
                 .Names = c("Condition1", "Condition2")), class = c("table", "matrix"))
> print(x)
          Condition2
Condition1    Yes     No    Sum
       Yes  42,31   2,56  44,87
       No   53,85   1,28  55,13
       Sum  96,15   3,85 100,00
> library(knitr)
> kable(x)
|id   |   Yes|    No|    Sum|
|:----|-----:|-----:|------:|
|Yes  |  42,3|  2,56|   44,9|
|No   |  53,8|  1,28|   55,1|
|Sum  |  96,2|  3,85|  100,0|

编辑knitr:::kable_mark:我在函数中找到了这种行为的原因。但现在我不明白如何使它更灵活。

4

2 回答 2

2

一种替代方法kable可能是通用 S3 方法pander

> library(pander)
> pander(x, style = 'rmarkdown')


|  &nbsp;   |  Yes  |  No   |  Sum  |
|:---------:|:-----:|:-----:|:-----:|
|  **Yes**  | 42.31 | 2.564 | 44.87 |
|  **No**   | 53.85 | 1.282 | 55.13 |
|  **Sum**  | 96.15 | 3.846 | 100   |

如果您需要将小数点设置为逗号,请在之前设置相关选项并在您的 R 会话中使用它:

> panderOptions('decimal.mark', ',')
> pander(x, style = 'rmarkdown')


|  &nbsp;   |  Yes  |  No   |  Sum  |
|:---------:|:-----:|:-----:|:-----:|
|  **Yes**  | 42,31 | 2,564 | 44,87 |
|  **No**   | 53,85 | 1,282 | 55,13 |
|  **Sum**  | 96,15 | 3,846 | 100   |

还有一些其他可能的调整:http ://rapporter.github.io/pander/#pander-options

于 2013-11-09T21:19:59.150 回答
1

我认为最简单的方法是彻底淘汰和更换kable_mark。注意:这很脏——但它似乎可以工作,而且目前还没有自定义kable_mark工作方式的方法(不过你可以向 knitr 提交补丁)。

km <- edit(knitr:::kable_mark)
# Now edit the code and remove lines 7 and 8.

unlockBinding('kable_mark', environment(knitr:::kable_mark))
assign('kable_mark', km, envir=environment(knitr:::kable_mark))

解释:首先我们编辑函数并将修改后的定义存储在一个临时变量中。我们删除这两行

if (grepl("^\\s*$", cn[1L])) 
    cn[1L] = "id"

…当然,您也可以对修改后的函数进行硬编码,而不是对其进行编辑,或者完全更改函数。

接下来我们使用unlockBindingmakeknitr:::kable_mark可覆盖。如果我们不这样做,下一个assign命令将不起作用。

最后,我们将修补后的函数分配回knitr:::kable_mark. 完毕。

于 2013-11-09T15:33:15.170 回答