热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Golang办公自动化自动化管理文件和文件夹遍历文件夹

自动化管理文件和文件夹遍历文件夹遍历文件夹及子文件夹包名:pathfilepath原型:funcWalk(rootstring,walkFnWal
自动化管理文件和文件夹

遍历文件夹


遍历文件夹及子文件夹

包名:path/filepath
原型:func Walk(root string, walkFn WalkFunc) error
作用:Walk 函数会遍历 root 指定的目录下的文件树,对每一个该文件树中的目录和文件都会调用 walkFn,包括 root 自身。所有访问文件 / 目录时遇到的错误都会传递给 walkFn 过滤。文件是按词法顺序遍历的,这让输出更漂亮,但也导致处理非常大的目录时效率会降低。Walk 函数不会遍历文件树中的符号链接(快捷方式)文件包含的路径。

包名:path/filepath
原型:type WalkFunc func(path string, info os.FileInfo, err error) error
作用:Walk 函数对每一个文件 / 目录都会调用 WalkFunc 函数类型值。调用时 path 参数会包含 Walkroot 参数作为前缀;就是说,如果 Walk 函数的 rootdir ,该目录下有文件 a,将会使用 dir/a 调用 walkFn 参数。walkFn 参数被调用时的 info 参数是 path 指定的地址(文件 / 目录)的文件信息,类型为 os.FileInfo

如果遍历 path 指定的文件或目录时出现了问题,传入的参数 err 会描述该问题,WalkFunc 类型函数可以决定如何去处理该错误( Walk 函数将不会深入该目录);如果该函数返回一个错误,Walk 函数的执行会中止;只有一个例外,如果 WalkwalkFn 返回值是 SkipDir,将会跳过该目录的内容而 Walk 函数照常执行处理下一个文件。

示例:

package mainimport ("fmt""os""path/filepath"
)func walkFunc(path string, info os.FileInfo, err error) error {fmt.Printf("%s\n", path)return nil
}func main() {//遍历打印所有的文件名filepath.Walk(`F:\blog`, walkFunc)
}

普通遍历文件夹

示例:

package mainimport ("fmt""os"
)func main() {f, err := os.Open(`F:\blog\officeauto`)if err != nil {panic(err)}fs, err := f.Readdir(0)if err != nil {panic(err)}for _, f := range fs {fmt.Println(f.Name())}}

示例:

package mainimport ("fmt""io/ioutil"
)func main() {fs, err := ioutil.ReadDir(`F:\blog\officeauto`)if err != nil {panic(err)}for _, f := range fs {fmt.Println(f.Name())}}

递归遍历文件夹

示例:

package mainimport ("fmt""io/ioutil"
)func WalkDir(filepath string, level int) ([]string, error) {prefix :&#61; "|"for i :&#61; 0; i < level; i&#43;&#43; {prefix &#43;&#61; "------"}// files为当前目录下的所有文件名称【包括文件夹】files, err :&#61; ioutil.ReadDir(filepath)if err !&#61; nil {return nil, err}var allfile []stringfor _, v :&#61; range files {// 全路径 &#43; 文件名称fullPath :&#61; filepath &#43; "\\" &#43; v.Name()// 如果是目录if v.IsDir() {allfile &#61; append(allfile, prefix &#43; v.Name())// 遍历改路径下的所有文件a, _ :&#61; WalkDir(fullPath, level &#43; 1)allfile &#61; append(allfile, a...)} else {// 如果不是文件夹&#xff0c;就直接追加到路径下allfile &#61; append(allfile, prefix &#43; v.Name())}}return allfile, nil
}func main() {files, _ :&#61; WalkDir(&#96;F:\blog&#96;, 1)for _, v :&#61; range files {fmt.Println(v)}
}


推荐阅读
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了logistic回归(线性和非线性)相关的知识,包括线性logistic回归的代码和数据集的分布情况。希望对你有一定的参考价值。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • 原文地址:https:www.cnblogs.combaoyipSpringBoot_YML.html1.在springboot中,有两种配置文件,一种 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 本文介绍了一种划分和计数油田地块的方法。根据给定的条件,通过遍历和DFS算法,将符合条件的地块标记为不符合条件的地块,并进行计数。同时,还介绍了如何判断点是否在给定范围内的方法。 ... [详细]
author-avatar
兰花m123_680
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有