我有一个包含许多csv文件的文件夹。我这样看他们
files <- list.files(pattern = "*.csv")
[1] "ETo_1980.csv" "ETo_1981.csv" "ETo_1982.csv" "ETo_1983.csv" "ETo_1984.csv" "ETo_1985.csv"
[7] "ETo_1986.csv" "ETo_1987.csv" "ETo_1988.csv" "ETo_1989.csv" "ETo_1990.csv" "ETo_1991.csv"
[13] "ETo_1992.csv" "ETo_1993.csv" "ETo_1994.csv" "ETo_1995.csv" "ETo_1996.csv" "ETo_1997.csv"
[19] "ETo_1998.csv" "ETo_1999.csv" "ETo_2000.csv" "ETo_2001.csv" "ETo_2002.csv" "ETo_2003.csv"
[25] "ETo_2004.csv" "ETo_2005.csv" "ETo_2006.csv" "ETo_2007.csv" "ETo_2008.csv" "ETo_2009.csv"
[31] "ETo_2010.csv" "ETo_2011.csv" "ETo_2012.csv" "ETo_2013.csv" "ETo_2014.csv" "ETo_2015.csv
现在我读了它们:
DT <- lapply(files, fread)
每个文件,我都想另存为文本文件(.txt)。如何将每个文件另存为具有相同名称的.txt?
lapply(DT, function(x) { write.table()})?
答案 0 :(得分:2)
我生成了一个名为list
的{{1}},其中包含两个分别名为x
和a
的对象。在循环中使用b
可自动命名文本文件,如下所示:paste0
和a.txt
。 b.txt
执行文件的实际保存。
write.table
使用x <- list(a=c(1,2), b=c(3,4))
for(i in 1:length(x)){
write.table(x[[i]], paste0(names(x)[i], ".txt"), col.names = F)
}
查看文件是否已保存在您的工作目录中。
list.files
答案 1 :(得分:1)
尝试使用read.csv
读取CSV文件,然后使用write.csv
编写它们:
lapply(files, function(x) {
df <- read.csv(file=x)
name <- sub("\\.csv$", "\\.txt", x)
write.csv(df, file=name)
})
答案 2 :(得分:0)
改为遍历索引,然后创建要保存为的文件名的向量:
txt_files <- sub("csv$","txt",files)
lapply(seq_along(DT), function(x) write.table(DT[[x]], txt_files[x]))
请注意,您可能还希望从输出中排除row.names。