gpt4 book ai didi

将目录树表示为递归列表

转载 作者:行者123 更新时间:2023-12-04 03:58:57 25 4
gpt4 key购买 nike

我被困在一项特定的任务上。我想要的是一个给定目录路径的函数,该函数将返回递归列表作为输出。

输出的形式应为myList $ dir $ subdir $ subdir $ fullFilePath

所以基本上我想将目录树表示为某个列表。我获得了所有文件,获得了每个文件的所有子目录,但是对于如何将它们全部放入具有多个级别的列表中,我还是很固执。

最佳答案

这是使用递归的解决方案:

tree.list <- function(file.or.dir) {
isdir <- file.info(file.or.dir)$isdir
if (!isdir) {
out <- file.or.dir
} else {
files <- list.files(file.or.dir, full.names = TRUE,
include.dirs = TRUE)
out <- lapply(files, tree.list)
names(out) <- basename(files)
}
out
}

我已经在一个小目录上对它进行了测试
test.dir <- tree.list("./test")
test.dir
# $a
# $a$`1.txt`
# [1] "./test/a/1.txt"
#
# $a$aa
# $a$aa$`2.txt`
# [1] "./test/a/aa/2.txt"
#
# $b
# $b$`3.txt`
# [1] "./test/b/3.txt"

如果这太慢,无法满足您的需求,我会考虑将所有文件读入 list.filesrecursive = TRUE的单个调用中,然后进行一些解析。

关于将目录树表示为递归列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14188197/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com