作为更大脚本的一部分,我需要移动所有< .csv>文件从一个目录到另一个目录。我写了一个简单的脚本来做它,并且工作正常,但由于某种原因,它现在不能正常工作,我很想弄清楚我做错了什么。
代码是:
rawPath <- "./test_dir1"
dataPath <- "./test_dir2"
dataFiles <- dir(rawPath, "*.csv", ignore.case = TRUE, all.files = TRUE)
file.copy(dataFiles, dataPath, overwrite = TRUE )
但是我收到以下错误:
警告讯息:
1: In file.copy(dataFiles, dataPath, overwrite = TRUE) : problem copying .\test_dir1\11085.lis.csv to C:\Users\Desktop\test_dir2\11085.lis.csv: No such file or directory
One error message for each file
请在以下链接中找到试用目录和文件,它们是我的简化版本: https://www.dropbox.com/sh/7eqvyugc472w19i/AACIjlytbB4s55X0Ga1hmKQka?dl=0
任何帮助将不胜感激。谢谢!
答案 0 :(得分:3)
您的问题是您已经提取了相对于rawPath
的文件名,然后在您位于其他目录时尝试在file.copy
中使用该文件名。运行代码,请查看dataFiles
:
dataFiles
# [1] "11085.lis.csv" "13087.lis.csv" "17089.lis.csv" "5081.lis.csv" "7083.lis.csv"
你想要
file.copy(paste(rawPath, dataFiles, sep = .Platform$file.sep), dataPath, overwrite = TRUE)
# [1] TRUE TRUE TRUE TRUE TRUE
或者:
file.copy(file.path(rawPath, dataFiles), dataPath, overwrite = TRUE)
# [1] TRUE TRUE TRUE TRUE TRUE
要重现:
dir.create("test_dir1")
dir.create("test_dir2")
files <- paste0(c(5081, 7083, 11085, 13087, 17089), ".lis.csv")
file.create(paste("test_dir1", files, sep = .Platform$file.sep))
# [1] TRUE TRUE TRUE TRUE TRUE
dir("test_dir1")
# [1] "11085.lis.csv" "13087.lis.csv" "17089.lis.csv" "5081.lis.csv" "7083.lis.csv"
dir("test_dir2")
# character(0)
rawPath <- "./test_dir1"
dataPath <- "./test_dir2"
dataFiles <- dir(rawPath, "*.csv", ignore.case = TRUE, all.files = TRUE)
# To reproduce the error:
file.copy(dataFiles, dataPath, overwrite = TRUE )
# To run without error:
file.copy(file.path(rawPath, dataFiles), dataPath, overwrite = TRUE)