在R中,我有10个固定宽度的文本文件,分为8个部分。如何提取80个文件,分成各自的文件并组合部分?

问题描述 投票:0回答:1

所以我有80个文件名格式的文件:

P.A3588.ACO.CCLF0.ROW1.ROW30000
P.A3588.ACO.CCLF1.ROW1.ROW30000
P.A3588.ACO.CCLF0.ROW30001.ROW60000

有80个固定宽度的文本文件:10个CCLF编号(CCLF0,CCLF1,...,CCLF9)中的每一个都有8个部分。我希望能够按CCLF编号分组,应用列宽矢量,并绑定CCLF部分的行。

以下是我到目前为止所尝试的内容。它不起作用,但给出了我正在尝试的想法。

filenames <- list.files(dataPath)
names <- substr(filenames,13,17)

CCLF1_width <- c(13,6,11,2,10,10,1,1,7,7,2,17,1,2,2,4,1,10,10,10,10,10,2,10,10,10,11,2,2,1,1,1)
CCLF2_width <- c(13,10,11,2,10,10,4,10,5,11,6,10,10,24,17,2,2,2,2,2)
CCLF3_width <- c(13,11,2,2,7,10,11,6,10,10,1)
CCLF4_width <- c(13,11,2,1,2,7,11,6,10,10,7,1)
CCLF5_width <- c(13,10,11,2,10,10,3,2,2,1,2,10,10,5,15,1,7,10,10,2,2,2,10,10,40,11,17,24,2,2,2,2,2,2,7,7,7,7,7,7,7,7,1)
CCLF6_width <- c(13,10,11,2,10,10,1,2,10,10,5,15,1,10,10,2,2,2,10,10,40,11,17,2)
CCLF7_width <- c(13,11,11,2,10,2,20,1,1,24,9,2,20,13,2,10,10,12,9)
CCLF8_width <- c(11,2,3,5,10,1,1,3,2,2,10,10,10,30,15,40,1,1)
CCLF9_width <- c(11,11,10,10,12)
CCLF0_width <- c(11,11)

for (i in length(filenames)){
  assign(paste0(substr(filenames,13,17)), read_fwf(grepl("CCLF1",filenames),paste0(i,"_width")))
  }
r for-loop fixed-width file-import
1个回答
1
投票

您可以使用list.files与参数recursive = Truefull.names = TRUE获取所有80个txt文件的文件路径,然后使用lapplyforread.table读取一个list中有80个元素的所有文件,使用do.call(rbind,your_list)将列表合并为一个数据帧。

filename<-list.files(folder_path,recursive = T,pattern = ".txt",full.names = T)
all_file<-lapply(filename,read.table)
df<-do.call(rbind,all_file)
© www.soinside.com 2019 - 2024. All rights reserved.