R Shiny DataTables:不是按列而是按行格式化数字

R Shiny DataTables: Format numbers not by column but by row

我的数据是这样的矩阵:

             Buy and Hold              Strategy
[1,]    1.0000000000000000   19.0000000000000000
[2,]   -0.6300786023496699   -0.2361973739022651
[3,]   -0.0872213557701079   -0.0244237977843418
[4,]   -0.3461103323781194   -0.1010012410191289
[5,]    0.0000000000000000    0.4949083503054990
[6,]    0.2520044841505053    0.2418168087629348
[7,]   -0.7946470924762163   -0.7731378277502762
[8,] 1864.0000000000000000 1707.0000000000000000

如您所见,我需要按行而不是按列进行格式化。例如 [1,] 应该没有小数,所以有一个 1 和一个 19。但是行 [2,]-Row[7,] 应该是一个百分比,例如 xx.x% 和 Row[8,]没有小数的数字。我怎样才能做到这一点?我不知道如何使用这些回调函数,我想这就是解决方案..

您可以使用 rowCallback 函数:

library(DT)

data <- matrix(c(0,0.64,-0.76234,0.43,1,19),nrow=3,byrow=T)

    datatable(data,options=list(
            rowCallback=JS("function( row, data, index ) {
                           $('td:eq(0)', row).html(data[0] % 1 != 0 | data[0]==0 ? (data[0]*100).toFixed(1) +'%':data[0]);
                           $('td:eq(1)', row).html(data[1] % 1 != 0 | data[1]==0 ? (data[1]*100).toFixed(1) +'%':data[1]);
                           }
                           ")))

此示例会将数字乘以 100,四舍五入为小数点后 1 位,如果数字有小数部分或为 0,则添加百分号。如果没有,则保持原样。

它只对数据表的第一列和第二列执行此操作。