递归文件夹并树形打印

递归文件夹并树形打印

今天,一个网友问了这个问题,下班后就动手写给他了,顺便记录下。哈哈,记得刚学Java那会儿写过这玩意。

package com.billstudy.demo;

import java.io.File;

/**
 * Folder recursion show 
 * @author Bill
 * @since V1.0 2015/01/22
 */
public class FileRecursion {
	public static void main(String[] args) {
		// source file direction 
		String sourceTargetFilePath = "E:/alibaba";
		
		File sourceTargetFile = new File(sourceTargetFilePath);
		
		System.out.println(sourceTargetFilePath);
		
		recursionFile(sourceTargetFile,0L);
		
	}

	/**
	 * recursion file 
	 * @param file
	 */
	private static void recursionFile(File file,long level) {
		if(file.isFile()){
			System.out.println(printFilePath(level) + file.getName());;
		}else{
			File[] files = file.listFiles();
			for (File innerFile : files) {
				System.out.println(printFilePath(level) + innerFile.getName());
				if(innerFile.isDirectory()){
					// continue recursion 
					level++;
					recursionFile(innerFile,level);
					level--;
				}
			}
		}
	}

	/**
	 * print file path by level 
	 * @param file
	 * @param level
	 */
	private static String printFilePath(long level) {
		StringBuilder tree = new StringBuilder("|--");
		for (int i = 0; i < level; i++)
			tree.append("|--");
		return tree.toString();
	}
}

 文件结构:


控制台输出

遇到文件夹就深入,否则就打印结束递归。 

版权声明:本文为博主原创文章,未经博主允许不得转载。

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注