zoukankan      html  css  js  c++  java
  • 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;
            }
            }
            
        
    
    }
  • 相关阅读:
    MinGW离线包下载地址
    词法分析器--DFA(c++实现)
    linux下shell统计文件目录下所有代码行数
    四则运算表达式
    BliBli抢楼全攻略
    python 电影下载链接爬虫
    in, out, ref
    联合查询
    SQL语句大全
    LINQ
  • 原文地址:https://www.cnblogs.com/yeyangtao/p/10807551.html
Copyright © 2011-2022 走看看