作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有超过 10000 个变量的 csv 文件。我想使用 vroom 读入它们,并希望将第 1 列标识为日期,将第 2 列标识为字符,将第 3 和 4 列标识为整数,将所有其余列标识为 double 。我该怎么做?
我的代码看起来像这样,但是失败了。
data81 <- vroom(fname_1981_2010, col_types = c(Date = col_date(), MonthDay = col_character(), doy = col_integer(), (.) = col_double()))
告诉 vroom 在其余列中读取为 double (替换我代码中的 (.))的语法是什么?谢谢。
最佳答案
可以通过 cols()
的 .default
参数来实现:
library(vroom)
set.seed(42)
d <- data.frame(
date = sample(seq(as.Date('1999/01/01'), as.Date('2000/01/01'), by="day"), 12),
MonthDay = sample(LETTERS[1:7], 12, replace = TRUE),
doy = 1:12,
col4 = runif(12),
col5 = runif(12),
col6 = runif(12)
)
fname_1981_2010 <- "fname_1981_2010.csv"
write.csv(d, fname_1981_2010, row.names = FALSE)
vroom(fname_1981_2010, col_types = cols(date = col_date(), MonthDay = col_character(),
doy = col_integer(), .default = col_double()))
#> # A tibble: 12 x 6
#> date MonthDay doy col4 col5 col6
#> <date> <chr> <int> <dbl> <dbl> <dbl>
#> 1 1999-02-18 D 1 0.514 0.208 0.619
#> 2 1999-11-17 A 2 0.390 0.907 0.333
#> 3 1999-06-02 E 3 0.906 0.612 0.347
#> 4 1999-03-15 F 4 0.447 0.380 0.398
#> 5 1999-08-16 D 5 0.836 0.436 0.785
#> 6 1999-05-26 B 6 0.738 0.0374 0.0389
#> 7 1999-05-02 B 7 0.811 0.974 0.749
#> 8 2000-01-01 G 8 0.388 0.432 0.677
#> 9 1999-05-08 C 9 0.685 0.958 0.171
#> 10 1999-10-30 A 10 0.00395 0.888 0.261
#> 11 1999-01-24 A 11 0.833 0.640 0.514
#> 12 1999-11-23 C 12 0.00733 0.971 0.676
关于r - 使用 vroom 读取日期列和所有其他列作为 R 中的两倍,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68058569/
我有超过 10000 个变量的 csv 文件。我想使用 vroom 读入它们,并希望将第 1 列标识为日期,将第 2 列标识为字符,将第 3 和 4 列标识为整数,将所有其余列标识为 double 。
我有一个 .csv文件大小为 112GB 但都不是 vroom也不是 data.table::fread会打开它。即使我要求读取 10 行或几列,它也会提示映射错误:无法分配内存。 df<-d
我想要做的是,通过我的应用程序计算物理汽车的转速(“vroom”声音)。我在 ReactNative 中编码。而且我不打算创造一些复杂的东西,比如与汽车的内置计算机进行通信或任何这样做的东西。 但相反
我有一个 csv.gz 文件(据我所知)压缩前的大小为 70GB。我的机器有 50GB 的 RAM,所以无论如何我永远无法在 R 中打开它。 例如,我可以按如下方式加载前 10m 行: library
我是一名优秀的程序员,十分优秀!