zoukankan      html  css  js  c++  java
  • 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)
    }
    
  • 相关阅读:
    长春区域赛总结
    HDU 4297 One and One Story (LCA>RMQ)
    SRM 578 div1
    开学,网赛,压力。。。
    HDU 4291 A Short problem
    最大密集子图(POJ 3155)
    ubuntu安装sunjdk1.6
    【转】容斥原理
    生成树计数问题(SPOJ 104 Highways)
    Tonelli–Shanks Algorithm 二次剩余系解法 (Ural 1132. Square Root)
  • 原文地址:https://www.cnblogs.com/zheng-chuang/p/6193090.html
Copyright © 2011-2022 走看看