我有以下示例文件:
"id";"PCA0";"PCA1";"PCA2"
1;6.142741644872954;1.2075898020608253;1.8946959360032403
2;-0.5329026419681557;-8.586870627925729;4.510113575138726
当我尝试阅读时:
d <- read.table("file.csv", sep=";", header=T)
id
是整数列,PCA0
是数字,所有后续列都是因子
class(d$iid)
[1] "integer"
class(d$PCA0)
[1] "numeric"
class(d$PCA1)
[1] "factor"
class(d$PCA2)
[1] "factor"
为什么其他列也不是数字?
我知道如何转换列,但我希望我的脚本能够在不手动转换类型的情况下工作。为什么不识别数字列?
答案 0 :(得分:10)
正如@MrFlick所说:数字太多了。
你可以通过指定colClasses
参数来强制你想要的东西:
read.table("test.csv",
sep=";",
header=TRUE,
colClasses=c("integer","numeric","numeric","numeric"))
require(data.table)
d <- fread("test.csv")
然后修改为存储的最大精度:
d[,PCA0 := sprintf("%.15E",PCA0)]
d[,PCA1 := sprintf("%.15E",PCA1)]
d[,PCA2 := sprintf("%.15E",PCA2)]
给出:
> d
id PCA0 PCA1 PCA2
1: 1 6.142741644872954E+00 1.207589802060825E+00 1.8946959360032403
2: 2 -5.329026419681557E-01 -8.586870627925729E+00 4.510113575138726
注意:fread
应该更快+更快。
答案 1 :(得分:8)
这是R 3.1中的变更。就此问题much discussion on the R-devel list。基本上,如果一个数字有太多的数字,它就会被转换为一个因子。在3.1.1中可以恢复此行为,但据我所知,没有设置发布日期。