打印文件路径(打印树结构类似)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u012266559/article/details/83106994

文件结构本身就是一个树形结构,下面所用的思想就可以用在树结构上。
利用一个数组记录从根到当前节点的路径例如【root-node1-node2-…-node_now】。如果当前节点node_now没有子节点,就回退数组,删除最后一个元素,并在最后添加临节点。

打印完整路径(golang)

func Walkdir(root string, record []string, depth int64) {
	dirs, _ := ioutil.ReadDir(root)

	hasSubdir := false
	for _, dir := range dirs {
		if dir.IsDir() {
			hasSubdir = true
			record = append(record, dir.Name())
			depth++
			Walkdir(root + string(os.PathSeparator) + dir.Name(), record, depth)
		}
	}

	if ! hasSubdir {
		log.Println(record, depth)
	}

	record[depth-1] = ""
}

func WalkCmds(root string) {
	record := make([]string, 0)
	Walkdir(root, record, 0)
}

tree 的c实现(go实现更容易)

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <fcntl.h>
#include <errno.h>
#include <string.h>
#include <dirent.h>
 
//自定义错误处理函数
void my_error(const char *strerr)
{
    perror(strerr);
    exit(1);
}
 
//输出目录结构
void PrintDirentStruct(char direntName[], int level)
{
    //定义一个目录流指针
    DIR *p_dir = NULL;
 
    //定义一个目录结构体指针
    struct dirent *p_dirent = NULL;
 
    //打开目录,返回一个目录流指针指向第一个目录项
    p_dir = opendir(direntName);
    if(p_dir == NULL)
    {
        my_error("opendir error");
    }
 
    //循环读取每个目录项, 当返回NULL时读取完毕
    while((p_dirent = readdir(p_dir)) != NULL)
    {
        //备份之前的目录名
        char *backupDirName = NULL;
 
        if(p_dirent->d_name[0] == '.')
        {
            continue;
        }
 
        int i;
        for(i = 0; i < level; i++)
        {
            printf("|");
            printf("     ");
        }
        printf("|--- ");
        printf("%s\n", p_dirent->d_name);
 
 
        //如果目录项仍是一个目录的话,进入目录
        if(p_dirent->d_type == DT_DIR)
        {
            //当前目录长度
            int curDirentNameLen = strlen(direntName) + 1;
 
            //备份
            backupDirName = (char *)malloc(curDirentNameLen);
            memset(backupDirName, 0, curDirentNameLen);
            memcpy(backupDirName, direntName, curDirentNameLen);
 
            strcat(direntName, "/");
            strcat(direntName, p_dirent->d_name);
            PrintDirentStruct(direntName, level + 1);
 
            //恢复之前的目录名
            memcpy(direntName, backupDirName, curDirentNameLen);
            free(backupDirName);
            backupDirName = NULL;
        }
 
    }
 
    closedir(p_dir);
 
}
 
int main(int argc , char *argu[])
{
    //目录名
    char direntName[256];
    memset(direntName, 0, sizeof(direntName));
 
    if(argc == 1)
    {
        direntName[0] = '.';
    }
    else if(argc == 2)
    {
        strcat(direntName, argu[1]);
    }
    else
    {
        my_error("argument error");
    }
 
    //输出目录结构
    printf("%s\n", direntName);
    PrintDirentStruct(direntName, 0);
    return 0;
 
}

猜你喜欢

转载自blog.csdn.net/u012266559/article/details/83106994
今日推荐