golang中怎么利用递归构建一个无限级树状目录
发表于:2025-01-31 作者:千家信息网编辑
千家信息网最后更新 2025年01月31日,golang中怎么利用递归构建一个无限级树状目录,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。package maini
千家信息网最后更新 2025年01月31日golang中怎么利用递归构建一个无限级树状目录
golang中怎么利用递归构建一个无限级树状目录,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
package mainimport ( "encoding/json" "fmt" "os" "path/filepath" "sort")func main() { rootpath := "D:\\projects" root := FileNode{"projects", rootpath, []*FileNode{}} fileInfo, _ := os.Lstat(rootpath) walk(rootpath, fileInfo, &root) data, _ := json.Marshal(root) fmt.Printf("%s", data)}type FileNode struct { Name string `json:"name"` Path string `json:"path"` FileNodes []*FileNode `json:"children"`}func walk(path string, info os.FileInfo, node *FileNode) { // 列出当前目录下的所有目录、文件 files := listFiles(path) // 遍历这些文件 for _, filename := range files { // 拼接全路径 fpath := filepath.Join(path, filename) // 构造文件结构 fio, _ := os.Lstat(fpath) // 将当前文件作为子节点添加到目录下 child := FileNode{filename, fpath, []*FileNode{}} node.FileNodes = append(node.FileNodes, &child) // 如果遍历的当前文件是个目录,则进入该目录进行递归 if fio.IsDir() { walk(fpath, fio, &child) } } return}func listFiles(dirname string) []string { f, _ := os.Open(dirname) names, _ := f.Readdirnames(-1) f.Close() sort.Strings(names) return names}
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对的支持。
目录
文件
递归
帮助
清楚
内容
对此
文章
新手
更多
知识
结构
节点
行业
资讯
资讯频道
路径
难题
需求
频道
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
安全生产管理设置服务器地址
邮件服务器方案
出名大型生存服务器
丽水数据网络技术哪个好
订阅号群发数据库
网络安全墙纸
关于网络安全绿色上网的绘画
互联网科技下脱发险
服务器操作系统维护
软件开发遇到问题难受痛苦
2021网络安全直播视频
棒的cc防护服务器
自考计算机网络技术考试科目
老笔记本改造成云存储服务器
海珠网络安全运维公司
pc软件开发联系方式
弘业期货软件开发待遇
无法访问服务器投屏
腾讯数据库个人能提取数据吗
温州工业软件开发流程
服务器引导文件怎么打开
厦门计算机软件开发公司
文明六未登录文明服务器
个人名义软件开发
高中网络安全手抄报模板大全
默纳克服务器调试完如何退出
导入sql数据库慢
自建服务器免流
opcua客户端无法连接服务器
要树立的网络安全观