繁体   English   中英

不会破坏列名的data.frame

[英]data.frame without ruining column names

有没有一种方法可以使用data.frame而不会破坏列名?

我有以下结构:

$`Canon PowerShot`
[1] 9.997803e-01 9.997318e-01 3.327920e-01 3.327920e-01 9.988220e-01
[6] 4.030871e-05 4.928497e-05

$`Casio Exilim`
[1] 5.322024e-06 9.999646e-01 5.322024e-06 5.322024e-06 9.999646e-01
[6] 5.322024e-06 9.999646e-01

$FinePix
[1] 3.850036e-05 9.998887e-01 6.650074e-02 6.650074e-02 9.998465e-01
[6] 9.998465e-01 4.345598e-05

$`Kodak EasyShare`
[1] 3.548812e-05 9.998604e-01 3.996137e-01 3.996137e-01 9.987841e-01
[6] 3.179604e-05 2.789861e-05

$`Nikon Coolpix series`
[1] 9.156401e-02 9.998091e-01 1.995972e-01 1.995972e-01 9.996341e-01
[6] 7.033741e-05 8.499410e-05

但是在使用do.call(data.frame, my_list) ,我得到了:

  Canon.PowerShot Casio.Exilim      FinePix Kodak.EasyShare
1    9.997803e-01 5.322024e-06 3.850036e-05    3.548812e-05
2    9.997318e-01 9.999646e-01 9.998887e-01    9.998604e-01
3    3.327920e-01 5.322024e-06 6.650074e-02    3.996137e-01
4    3.327920e-01 5.322024e-06 6.650074e-02    3.996137e-01
5    9.988220e-01 9.999646e-01 9.998465e-01    9.987841e-01
6    4.030871e-05 5.322024e-06 9.998465e-01    3.179604e-05
7    4.928497e-05 9.999646e-01 4.345598e-05    2.789861e-05
  Nikon.Coolpix.series
1         9.156401e-02
2         9.998091e-01
3         1.995972e-01
4         1.995972e-01
5         9.996341e-01
6         7.033741e-05
7         8.499410e-05

(请注意,列名中使用。而不是'')

您可以通过设置check.names = FALSE来停止R将名称更改为语法上有效的名称。 有关详细信息,请参见?data.frame

# assuming your data is in a list called my_list
do.call(data.frame, c(my_list, check.names = FALSE))

R中的data.frames实际上是列表。 因此,这也是有效的:

data.frame(my_list, check.names = FALSE)

知道这一点后,就可以在lapply上使用lapply了,我认为这很酷:

my_data <- data.frame(my_list, check.names = FALSE)
lapply(my_data, IQR)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM