File类的静态成员变量:
package dl.java.day24.Demo01;
import java.io.File;
/*
java.io.File类
文件和目录路径名的抽象表示形式
java把电脑中的文件和文件夹(目录)封装为一个File类,通过File类对文件和文件夹进行操作
File类的方法:
创建文件/文件夹
删除文件/文件夹
获取文件/文件夹
判断文件/文件夹是否存在
对文件进行遍历
获取文件的大小
File类是一个与系统无关的类,任何的操作系统都可以使用这个类中的方法
重点:
file:文件
directory:文件夹/目录
path:路径
*/
public class Demo01File {
public static void main(String[] args) {
/*
static String pathSeparator 与系统有关的路径分隔符,为了方便,它被表示为一个字符串。
static char pathSeparatorChar 与系统有关的路径分隔符。
static String separator 与系统有关的默认名称分隔符,为了方便,它被表示为一个字符串。
static char separatorChar 与系统有关的默认名称分隔符。
操作路径:路径不能写死了
C:\develop\a.txt windows
C:/develop/a.txt Linux
"C:"+File.separator+"develop"+File.separator+"a.txt"
*/
String pathSeparator = File.pathSeparator;
System.out.println(pathSeparator);//;路径分隔符 windows:分号 Linux:冒号
String separator = File.separator;
System.out.println(separator);// \文件名称分隔符 windows:反斜杠\ Linux:正斜杠/
}
}
File类的构造方法:
package dl.java.day24.Demo01;
import java.io.File;
/*
路径:
绝对路径:以盘符开始的路径
相对路径:是一个简化路径,如果使用当前项目的根目录,路径可以简化书写
注意:
1.路径是不区分大小写
2.路径中的文件名称分隔符windows使用反斜杠,反斜杠是转义字符,两个反斜杠代表一个普通的反斜杠
*/
public class Demo02File {
public static void main(String[] args) {
/*
File类的构造方法
*/
//show01();
//show02("c:\\","a.txt");
//show02("d:\\","a.txt");//d:\a.txt
show03();
}
/*
File(File parent, String child) 根据 parent 抽象路径名和 child 路径名字符串创建一个新 File 实例。
参数:把路径分为两部分
String parent:父路径
String child:子路径
好处:
父路径和子路径,可以单独书写,使用起来灵活,父路径和子路径都可以变化
父路径是File类型,可以使用File的方法对路径进行一些操作,再使用路径创建对象
*/
private static void show03() {
File parent = new File("c:\\");
File file = new File(parent,"hello.java");
System.out.println(file);//c:\hello.java
}
/*
File(String parent, String child) 根据 parent 路径名字符串和 child 路径名字符串创建一个新 File 实例。
参数:把路径分为两部分
String parent:父路径
String child:子路径
好处:
父路径和子路径,可以单独书写,使用起来灵活,父路径和子路径都可以变化
*/
private static void show02(String parent,String child) {
File file = new File(parent,child);
System.out.println(file);//c:\a.txt
}
/*
File(String pathname) 通过将给定路径名字符串转换为抽象路径名来创建一个新 File 实例。
参数: String pathname:字符串的路径名称
路径可以是以文件结尾,也可以是以文件夹结尾
路径可以是相对路径,也可以是绝对路径
路径可以是存在的,也可以是不存在的
创建的File对象,只是把字符串路径封装为File对象,不考虑路径的真假
*/
private static void show01() {
File f1 = new File("E:\\java\\java_project\\day11-code\\src\\a.txt");
System.out.println(f1);//重写了Object类的toString方法 E:\java\java_project\day11-code\src\a.txt
File f2 = new File("E:\\java\\java_project\\day11-code\\src");
System.out.println(f2);//E:\java\java_project\day11-code\src
File f3 = new File("b.txt");
System.out.println(f3);//b.txt
}
}
常用的方法:
获取功能的方法:
package dl.java.day24.Demo01;
import java.io.File;
/*
File类获取功能方法:
public String getAbsolutePath():返回File的绝对路径字符串
public String getPath():将File转换为路径名字符串
public String getName();返回File表示的文件名或目录名
public long length():返回File的文件长度
*/
public class Demo03File {
public static void main(String[] args) {
//show01();
//show02();
//show03();
show04();
}
/*
public long length():返回File的文件长度
获取的是构造方法指定文件的大小,以字节为单位
注意:
文件夹没有大小,不能获取文件夹大小
如果构造方法中给出路径不存在,那么length方法返回0
*/
private static void show04() {
File f1 = new File("D:\\licence.txt");
long l1 = f1.length();
System.out.println(l1);//18288字节
File f2 = new File("D:");
long l2 = f2.length();
System.out.println(l2);
}
/*
public String getName();返回File表示的文件名或目录名
获取的就是构造方法传递路径的结尾部分(文件/文件夹)
*/
private static void show03() {
File f1 = new File("E:\\java\\java_project\\day11-code\\a.txt");
String name1 = f1.getName();
System.out.println(name1);//a.txt
File f2 = new File("E:\\java\\java_project\\day11-code");
String name2 = f2.getName();
System.out.println(name2);//day11-code
}
/*
public String getPath():将File转换为路径名字符串
获取构造方法中的路径
toString方法调用的就是getPath方法
源码:
public String toString() {
return getPath();
}
*/
private static void show02() {
File f1 = new File("E:\\java\\java_project\\day11-code\\a.txt");
File f2 = new File("a.txt");
String path1 = f1.getPath();
String path2 = f2.getPath();
System.out.println(path1);//E:\java\java_project\day11-code\a.txt
System.out.println(path2);//a.txt
System.out.println(f1);//E:\java\java_project\day11-code\a.txt
System.out.println(f1.toString());//E:\java\java_project\day11-code\a.txt
}
/*
public String getAbsolutePath():返回File的绝对路径字符串
获取构造方法中的路径,无论绝对还是相对路径,getAbsolutePath返回的都是绝对路径
*/
private static void show01() {
File f1 = new File("E:\\java\\java_project\\day11-code\\a.txt");
String absolutePath1 = f1.getAbsolutePath();
System.out.println(absolutePath1);//E:\java\java_project\day11-code\a.txt
File f2 = new File("a.txt");
String absolutePath2 = f2.getAbsolutePath();
System.out.println(absolutePath2);//E:\java\java_project\a.txt
}
}
判断功能的方法:
package dl.java.day24.Demo01;
import java.io.File;
/*
File判断功能的方法:
public boolean exists():文件或目录是否存在
public boolean isDirectory():表示的是否为目录
public boolean isFile():表示的是否为文件
*/
public class Demo04File {
public static void main(String[] args) {
//show01();
show02();
}
/*
public boolean isDirectory():表示的是否为目录
判断构造方法中给定的路径是否以文件夹结尾
public boolean isFile():表示的是否为文件
判断构造方法中给定的路径是否以文件结尾
注意:
电脑的硬盘中只有文件/文件夹,两个方法是互斥的
都有使用前提:路径必须是存在的,否则都返回false
*/
private static void show02() {
File f1 = new File("D:\\licence1.txt");
//不存在,没必要获取
if (f1.exists()){
System.out.println(f1.isDirectory());
System.out.println(f1.isFile());
}
}
/*
public boolean exists():文件或目录是否存在
判断构造方法中的路径是否存在
存在:true 不存在:false
*/
private static void show01() {
File f1 = new File("D:\\licence.txt");
System.out.println(f1.exists());//true
}
}
创建删除功能的方法:
package dl.java.day24.Demo01;
import java.io.File;
import java.io.IOException;
/*
File类创建删除功能方法:
public boolean createNewFile():当且仅当具有该名称的问价不存在时,创建一个新的空文件
public boolean delete():删除此文件或目录
public boolean mkdir():创建目录
public boolean mkdirs():创建目录,包括任何必需但不存在的父目录
*/
public class Demo05File {
public static void main(String[] args) throws IOException {
//show01();
//show02();
show03();
}
/*
public boolean delete():删除此文件或目录
删除构造方法中给出的文件或文件夹
返回值:布尔值
true:文件/文件夹删除成功
false:文件夹中有内容,不会删除返回false;构造方法中的路径不存在返回false
注意:
delete方法是直接再硬盘删除文件/文件夹,不走回收站,删除要谨慎
*/
private static void show03() {
File f1 = new File("E:\\java\\java_project\\day11-code\\src\\dl\\java\\day24\\1.txt");
boolean b1 = f1.delete();
System.out.println("b1:"+b1);//b1:true
File f2 = new File("E:\\java\\java_project\\day11-code\\src\\1\\2\\3 ");
System.out.println(f2.delete());//true
File f3 = new File("E:\\java\\java_project\\day11-code\\src\\1");
System.out.println(f3.delete());//false
}
/*
public boolean mkdir():创建单级空文件夹
public boolean mkdirs():可以创建空单级文件夹和多级文件夹
创建文件的路径和名称再构造方法中给出(构造方法参数)
返回值:布尔值
true:文件夹不存在,创建文件夹,返回true
false:文件夹存在,不会创建,返回false;构造方法中给出的路径不存在返回false
注意:只能创建文件夹
*/
private static void show02() {
File f1 = new File("E:\\java\\java_project\\day11-code\\src\\1");
boolean b1 = f1.mkdir();
System.out.println(b1);//true
File f2 = new File("E:\\java\\java_project\\day11-code\\src\\1\\2\\3 ");
boolean b2 = f2.mkdirs();
System.out.println(b2);//true
}
/*
public boolean createNewFile():当且仅当具有该名称的问价不存在时,创建一个新的空文件
创建文件的路径和名称再构造方法中给出(构造方法参数)
返回值:布尔值
true:文件不存在,创建文件,返回true
false:文件存在,不会创建,返回false
注意:
1.只能创建文件
2.创建文件的路径必须存在,否则会抛出异常
*/
private static void show01() throws IOException {
File f1 = new File("E:\\java\\java_project\\day11-code\\src\\dl\\java\\day24\\1.txt");
boolean b1 = f1.createNewFile();
System.out.println("b1:"+b1);//b1:true
File f2 = new File("2.txt");
System.out.println(f2.createNewFile());//true
}
}
File类遍历目录方法:
package dl.java.day24.Demo01;
import java.io.File;
/*
File类遍历文件夹功能:
public String[] list():返回一个String数组,表示该目录中的所有子文件和目录
public File[] listFiles():返回一个String数组,表示该目录中的所有子文件和目录
注意:
list和listFiles方法遍历的是构造方法中的目录
如果构造方法中给出的目录不存在,就会抛出空指针异常
给出的不是目录,也会抛出空指针异常
*/
public class Demo06File {
public static void main(String[] args) {
//show01();
show02();
}
/*
public File[] listFiles():返回一个String数组,表示该目录中的所有子文件和目录
遍历构造方法中给出的目录,获取所有目录中的文件和目录,把文件和文件夹封装为File对象,多个File对象存储到File数组中
*/
private static void show02() {
File file = new File("E:\\java\\java_project\\day11-code\\src\\dl\\java\\day24");
File[] files = file.listFiles();
for (File f : files) {
System.out.println(f);//E:\java\java_project\day11-code\src\dl\java\day24\Demo01
}
}
/*
public String[] list():返回一个String数组,表示该目录中的所有子文件和目录
*/
private static void show01() {
File file = new File("E:\\java\\java_project\\day11-code\\src\\dl\\java\\day24");
String[] arr = file.list();
for (String fileName : arr) {
System.out.println(fileName);//Demo01
}
}
}