• go遍历目录


    package main
    
    import (
    	"fmt"
    	"io/ioutil"
    	"os"
    	"path/filepath"
    	"strings"
    )
    
    //获取指定目录下的所有文件,不进入下一级目录搜索,可以匹配后缀过滤。
    func ListDir(dirPth string, suffix string) (files []string, err error) {
    	files = make([]string, 0, 10)
    	dir, err := ioutil.ReadDir(dirPth)
    	if err != nil {
    		return nil, err
    	}
    	PthSep := string(os.PathSeparator)
    	suffix = strings.ToUpper(suffix) //忽略后缀匹配的大小写
    	for _, fi := range dir {
    		if fi.IsDir() { // 忽略目录
    			continue
    		}
    		if strings.HasSuffix(strings.ToUpper(fi.Name()), suffix) { //匹配文件
    			files = append(files, dirPth+PthSep+fi.Name())
    		}
    	}
    	return files, nil
    }
    
    //获取指定目录及所有子目录下的所有文件,可以匹配后缀过滤。
    func WalkDir(dirPth, suffix string) (files []string, err error) {
    	files = make([]string, 0, 30)
    	suffix = strings.ToUpper(suffix)                                                     //忽略后缀匹配的大小写
    	err = filepath.Walk(dirPth, func(filename string, fi os.FileInfo, err error) error { //遍历目录
    		//if err != nil { //忽略错误
    		// return err
    		//}
    		if fi.IsDir() { // 忽略目录
    			return nil
    		}
    		if strings.HasSuffix(strings.ToUpper(fi.Name()), suffix) {
    			files = append(files, filename)
    		}
    		return nil
    	})
    	return files, err
    }
    func main() {
    	files, err := ListDir("./", "")
    	fmt.Println(files, err)
    	files, err = WalkDir("./", "")
    	fmt.Println(files, err)
    }
    
  • 相关阅读:
    sparse用法matlab官方说明
    C++双向循环链表
    循环链表以及迭代器的使用c++
    顺序队列c++
    顺序栈c++
    尾插法链表
    邻接表建立图
    深度优先搜索树与广度优先搜索树
    tensorflow-笔记02
    深度学习-框架介绍
  • 原文地址:https://www.cnblogs.com/zheng-chuang/p/6193090.html
Copyright © 2020-2023  润新知