我有一个标识符列表保存为字符变量(uid_car)我有一个文件列表(file_list),标识符作为文件名的前缀(例如1000 _ * .file)
uid_car <-1000,1002,1004 .... len(170)file_list <-1000_01_.file,1001_02.file,1003_02.file,1002_01.file,1004_01.file ... len(~700)
在上面的例子中,我想循环遍历文件列表并复制具有uid_car中包含的前缀的文件。因此,只有文件1000_01.file,1002_01.file和1004_01.file将被复制到新路径。
下面的for循环一直有效,直到你点击uid_car中没有包含的第i个元素。
我尝试了一个可能有点整洁的mapply功能,但没有那么多写这些经验...任何帮助将不胜感激。
for (i in length_of_file_list) {
if (startsWith(file_list[i], uid_car[])) {
file.copy(file_list[i], new_path)
}
}
如果你想在一个循环中这样做,这可能会做你想要的:
uids_to_print <- c("1000", "1001", "1004")
filenames <-c("1000_01.file","1000_02.file","1001_01.file","1001_02.file","1002_01.file","1002_02.file","1003_01.file","1004_01.file")
# Iterate through each filename
for (filename in filenames) {
# Pull out the characters prior to the first underscore
filename_uid <- unlist(strsplit(filename, "_"))[1]
# Cheeck if it's in the list of ones to print
if(filename_uid %in% uids_to_print) {
# Put file operation inside this loop
}
}
例如,执行
for (filename in filenames) {
filename_uid <- unlist(strsplit(filename, "_"))[1]
if(filename_uid %in% uids_to_print) {
print(paste("copy", filename, sep=" "))
}
}
产量
"copy 1000_01.file"
"copy 1000_02.file"
"copy 1001_01.file"
"copy 1001_02.file"
"copy 1004_01.file"
我认为你不需要循环。
files.to.copy <- file_list[file_list %in% paste0(uid_car,'_01.file')]
file.copy(files.to.copy, new_path)