I/O————File对象
File文件对象
文件和文件夹都是用File代表
创建一个文件对象,(并不会有真正的文件或文件夹被创建)
File f1 = new File("d:/lolfilder"); System.out.println("f1的绝对路径:"+f1.getAbsolutePath()); File f2 = new File("lol.exe"); System.out.println("f2的绝对路径:"+f2.getAbsolutePath()); File f3 = new File(f1, "lol.exe"); System.out.println("f3的绝对路径:"+f3.getAbsolutePath()); //mkdir()创建文件夹 父文件夹不存在则创建失败 //f3.mkdir(); //mkdirs()创建文件夹 父文件夹不存在则创建父文件夹然后再创建该文件夹 f3.mkdirs(); System.out.println("f3是否存在:"+f3.exists()); //list()返回一个字符串数组包,含当前文件夹下的所有文件名称 String[] fStrings=f1.list(); for(String s:fStrings) { System.out.println(s); }
遍历文件夹练习
遍历C:\WINDOWS目录目录下所有的文件(不用遍历子目录)找出这些文件里,最大的和最小(非0)的那个文件,打印出他们的文件名
要求:最小的文件不能是0长度
实现思路:不遍历子目录较简单,建立最大文件和最小文件对象,然后用循环保证最大和最小。要注意最小文件不能是0,所以要给min一个值,要不然大小为0的文件比所有文件都小
public class test { /** * * 遍历c盘windows文件夹下的所有文件(不包括子目录下的),并列出最大和最小的 */ public static void main(String[] args) { File file = new File("C:\\Windows"); File max=new File(" "); File min = new File(" "); //用listFiles方法获得一个File类型的数组 File []fs = file.listFiles(); //foreach for(File f:fs) { //给min一个初值,要不然一直是最小的 if(min.length()==0) min=max; //比max大的,取代max if(max.length()<f.length()) { max= f; } //比min小的取代min if(min.length()>f.length()&&f.length()!=0) { min= f; } System.out.println("文件名为:"+f.getAbsolutePath()+"大小为:"+f.length()); } System.out.println("最大文件为:"+max.getAbsolutePath()+"大小为:"+max.length()); System.out.println("最小文件为:"+min.getAbsolutePath()+"大小为:"+min.length()); } }
接下来是要遍历子目录:
实现思路就是使用递归,如果它当前文件是文件夹就继续调用该方法
public class List { /** * * 使用递归遍历c盘windows文件夹下的所有文件(包括子目录下的),并列出最大和最小的 */ File max = new File(" "); File min = new File(" "); public void listFile(File file) { //如果f是一个文件夹,开始递归 if(file.isDirectory()) { File[] fs = file.listFiles(); if(null!=fs) for (File f : fs) { listFile(f); } } //如果file是文件 if(file.isFile()) { //给min一个初值,要不然一直是最小的 if(min.length()==0) min=max; //比max大的,取代max if(max.length()<file.length()) { max= file; } //比min小的取代min if(min.length()>file.length()&&file.length()!=0) { min= file; } return; } } }