合并 csv 文件中的特定列并将文件名用作 headers

Merge specific columns from csv files and use the filenames as headers

我想合并两个 csv 文件中的特定列并使用文件名作为列 header.In 在这个例子中,我想将每个文件的第三列合并到一个数据框中。 csv 文件具有相同的行数和列数。

示例数据集:

File1.csv

V1,V2,V3,V4
1,1986,64,61

File2.csv

V1,V2,V3,V4
1,1990,100,61

预期结果:

"File1","File2"
64,100

这是我的脚本:

my.file.list <- list.files(pattern = "*.csv")
my.list <- lapply(X = my.file.list, FUN = function(x) {
        read.csv(x, header=TRUE,colClasses = c("NULL", "NULL", "numeric",    "NULL"), sep = ",")[,1]
    })
my.df <- do.call("cbind", my.list)

如何根据文件名添加 headers 列?

我试过这个:

sub('.csv','',basename(my.file.list),fixed=TRUE)

但我不知道如何将其添加为 headers。

如有任何帮助,我将不胜感激。

my.file.list <- list.files(pattern = "*.csv")
my.list <- list()
for (i in 1:length(my.file.list)) {
    df <- read.csv(my.file.list[[i]], header=TRUE, sep=",")["V3"]
    names(df) <- paste0("FILE", i)
    my.list[[i]] <- df
}
my.df <- do.call("cbind", my.list)

@Tim Biegeleisen 非常感谢您的帮助。我现在明白了。这是您的答案的改进版本,我可以将其用于具有不同文件名的文件。

 my.file.list <- list.files(pattern = "*.csv")
 my.list <- list()
 for (i in 1:length(my.file.list)) {
   df <- read.csv(my.file.list[[i]], header=TRUE, sep=",")["V3"]
    names(df) <-paste0(sub('.csv','',basename(my.file.list[i]),fixed=TRUE), i)
 my.list[[i]] <- df
 }
 my.df <- do.call("cbind", my.list)