首页 > 解决方案 > 如何读取多个 csv 并在每个文件名中保留数字?

问题描述

我在一个文件夹中有多个 csv 文件,这些文件都没有标题。我想保留文件末尾数字列出的顺序。文件名是“output-1.csv”、“output-2.csv”等。有没有办法包含每个 csv 的文件名,所以我知道哪些数据对应于哪个文件。答案 [here][1] 接近我想要的。

library(tidyverse)

#' Load the data ----
mydata <-
  list.files(path = "C:\\Users\\Documents\\Manuscripts\\experiment1\\output",  
   pattern = "*.csv") %>%
  map_df( ~ read_csv(., col_names = F))
mydata

标签: rstringcsvtidyverse

解决方案


您可以使用:

library(tidyverse)

mydata <- list.files("C:\\Users\\Documents\\Manuscripts\\experiment1\\output", 
pattern = ".csv$", full.names = T) %>% 
  set_names(str_sub(basename(.), 1, -5)) %>% 
  map_dfr(read_csv, .id = "file")

推荐阅读