Java之File类及递归树形展示目录_20150804

Java之File类及递归树形展示目录

20150804


下面的构造函数可以用来生成File 对象:

         File(String directoryPath)
         File(String directoryPath, String filename)
         File(File dirObj, String filename)
这里,directoryPath是文件的路径名,filename 是文件名,dirObj 一个指定目录的File 对象。下面的例子创建了三个文件:f1,f2,和f3。第一个File对象是由仅有一个目录路径参数的构造函数生成的。第二个对象有两个参数——路径和文件名。第三个File对象的参数包括指向f1文件的路径及文件名。f3和f2指向相同的文件。
File f1 = new File("/");
File f2 = new File("/","autoexec.bat");
File f3 = new File(f1,"autoexec.bat");
注意:Java 能正确处理UNIX和Windows/DOS约定路径分隔符。如果在Windows版本的Java下用斜线(/),路径处理依然正确。记住,如果你用Windows/DOS使用反斜线(/)的约定,你需要在字符串内使用它的转义序列(//)。Java约定是用UNIX和URL风格的斜线来作路径分隔符。


下面以一个小例子来说明一下File类常用的方法:

目标:以树形结构把指定的目录及文件打印在控制台上

思想:递归

package day04;

import java.io.File;

/*
 * 打印树状目录
 * 核心方法:递归
 * 用到的方法:
 *   1)f.getName() ---获得该目录的名字
 *   2)f.list() ------列出该目录下所有的一级目录及文件,返回值String[]
 *    
 */
public class TestFile02 {
	
	public static void printFile(File f,int lever){
		for(int i=0;i<lever;i++){
			System.out.print("-");			
		}
		System.out.println(f.getName());
		if(f.isFile()){			
			return ;
		}else{
			String[] s=f.list();
			for(int i=0;i<s.length;i++){
				File f1=new File(f.getPath()+File.separator+s[i]);
				printFile(f1,lever+1);
			}
		}
		return ;
	}

	public static void main(String[] args) {
		//String path="/home/soft01/QXL";
		
		//可以用/也可以用File类提供的分隔符File.separator(建议用分隔符,不会有系统的问题)
		String path="F:/JavaTrain/Teaching"; 
		
		File f=new File(path);
		printFile(f,0);
	}

}


总结:File类常用的方法及属性都比较简单,基本上见名知意,不再啰嗦。特殊的几个在上面代码中有演示




  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
//显示任意一个目录的文件到TReeview中 unit uTreeViewDemo; interface uses  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,  Dialogs, ComCtrls, StdCtrls, FileCtrl; const  SELDIRHELP = 1000; type  TForm1 = class(TForm)   TreeView1: TTreeView;   Button1: TButton;   procedure Button1Click(Sender: TObject);  private   { Private declarations }  public   procedure GetDirectories(Tree: TTreeView; Directory: string; Item: TTreeNode;              IncludeFiles: Boolean);   { Public declarations }  end; var  Form1: TForm1; implementation {$R *.dfm} procedure TForm1.GetDirectories(Tree: TTreeView; Directory: string; Item: TTreeNode;                 IncludeFiles: Boolean); var  SearchRec: TSearchRec;  ItemTemp: TTreeNode; begin  TreeView1.Items.BeginUpdate;  if Directory[Length(Directory)] '\' then   Directory := Directory + '\';  if FindFirst(Directory + '*.*' , faDirectory, SearchRec) = 0 then  begin   repeat    if (SearchRec.Attr and faDirectory = faDirectory) and (SearchRec.Name[1] '.') then    begin     if (SearchRec.Attr and faDirectory > 0) then     Item := Tree.Items.AddChild(Item, SearchRec.Name);     ItemTemp := Item.Parent;     GetDirectories(Tree, Directory + SearchRec.Name, Item, IncludeFiles);     Item := ItemTemp;    end    else    if IncludeFiles then    if SearchRec.Name[1] '.' then     Tree.Items.AddChild(Item, SearchRec.Name);   until FindNext(SearchRec) 0;   FindClose(SearchRec);   TreeView1.Items.EndUpdate;  end; end; procedure TForm1.Button1Click(Sender: TObject); var  strOpenDir: string; begin  if SelectDirectory(strOpenDir, [sdAllowCreate, sdPerformCreate, sdPrompt],SELDIRHELP) then  try   GetDirectories(TreeView1, strOpenDir, nil, True);  except   ShowMessage('错误信息');  end; end; end.
作为AI语言模型,我无法直接操作前端,但是我可以提供一些Java代码来读取文件夹并生成树形结构。具体的前端代码需要根据您所使用的框架和库来实现。 可以使用Java中的File类来读取文件夹。以下是一个示例代码,它将打印出指定文件夹中的所有文件和文件夹以及它们的层次结构: ```java import java.io.File; public class DirectoryTree { public static void main(String[] args) { File directory = new File("/path/to/folder"); if (directory.exists()) { printDirectoryTree(directory, 0); } else { System.out.println("Directory not found."); } } private static void printDirectoryTree(File folder, int level) { if (folder.isFile()) { System.out.println(getIndent(level) + "- " + folder.getName()); } else { System.out.println(getIndent(level) + "+ " + folder.getName()); File[] files = folder.listFiles(); if (files != null) { for (File file : files) { printDirectoryTree(file, level + 1); } } } } private static String getIndent(int level) { StringBuilder sb = new StringBuilder(); for (int i = 0; i < level; i++) { sb.append("| "); } return sb.toString(); } } ``` 该代码将以以下形式输出文件夹中的内容: ``` + folder | + subfolder1 | | - file1.txt | | - file2.txt | + subfolder2 | | + subsubfolder1 | | | - file3.txt | | - file4.txt | - file5.txt ``` 您可以将这个代码结合前端框架来实现树形结构。例如,您可以使用React来实现一个递归组件,在组件中调用Java代码并将结果渲染为树形结构。以下是一个简单的示例代码: ```jsx import React, { useState, useEffect } from 'react'; function DirectoryTree() { const [tree, setTree] = useState([]); useEffect(() => { fetch('/api/directory') .then(response => response.json()) .then(data => setTree(data)); }, []); function renderTree(node) { if (node.isFile) { return <li>{node.name}</li>; } else { return ( <li> {node.name} <ul>{node.children.map(child => renderTree(child))}</ul> </li> ); } } return <ul>{tree.map(node => renderTree(node))}</ul>; } export default DirectoryTree; ``` 在此示例代码中,我们使用fetch API从后端API中获取树形结构数据,并使用递归组件将其渲染为树形结构。在这里,我们假设后端API将数据以以下格式返回: ```json [ { "name": "folder", "isFile": false, "children": [ { "name": "subfolder1", "isFile": false, "children": [ { "name": "file1.txt", "isFile": true }, { "name": "file2.txt", "isFile": true } ] }, { "name": "subfolder2", "isFile": false, "children": [ { "name": "subsubfolder1", "isFile": false, "children": [{ "name": "file3.txt", "isFile": true }] }, { "name": "file4.txt", "isFile": true } ] }, { "name": "file5.txt", "isFile": true } ] } ] ``` 您需要将这个数据格式化为您所需要的格式,并将其作为状态传递给递归组件。根据您的需求,您还可以添加其他功能,例如展开和收缩文件夹、搜索文件夹等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值