Java ファイルの存在/移動/コピー/削除(NIO.2のFiles)

JavaのNIO.2のFilesクラスのメソッドでファイルを操作するサンプルです。

確認環境
・Java 8

目次

サンプル ファイルの存在確認(exists/notExists)
  ファイルをコピーする(copy)
  ファイルを移動する(move)
  ファイル名を変更する(move)
  空ファイルを作成する(createFile)
  ファイルを削除する(deleteIfExists)
  ファイルのサイズを取得する(size)
  作成日時と更新日時を取得(readAttributes)
  一時ファイルを作成する(createTempFile)
参考 NIO.2のFilesクラス
  メソッドの引数に指定するPathオブジェクト

ファイルの存在確認(exists/notExists)

public static boolean exists(Path path,LinkOption... options)
public static boolean notExists(Path path,LinkOption... options)

existsメソッドとnotExistsメソッドで、ファイルの存在確認を行うサンプルです。

package test1;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;

public class Test1 {
	public static void main(String[] args) {
		
        Path path1 = Paths.get("D:\\Test3","test1.txt");
        
        if (Files.exists(path1)) {
            System.out.println("存在します");
        }
        if (Files.notExists(path1)) {
            System.out.println("存在しません");
        }
 	}
}

11行目のexistsメソッドは、ファイルが存在している場合、trueを返します。
存在していない場合、falseを返します。
14行目のnotExistsメソッドは、ファイルが存在していない場合、trueを返します。
存在している場合、falseを返します。

ファイルをコピーする(copy)

public static Path copy(Path source,Path target,CopyOption... options) throws IOException

copyメソッドで、ファイルのコピーを行うサンプルです。

package test1;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;

public class Test1 {
	public static void main(String[] args) {
        
        Path from1 = Paths.get("D:\\Test3","test1.txt");
        Path to1 = Paths.get("D:\\Test4","test1.txt");
		
        try {
			Files.copy(from1, to1);
		} catch (IOException e) {
			e.printStackTrace();
		}
 	}
}

14行目は、copyメソッドでtest3フォルダのtest1.txtをtest4フォルダにコピーしています。
コピー前に、D:\Test4\test1.txtが存在しているとエラーになります。
java.nio.file.FileAlreadyExistsException

ファイルを移動する(move)

public static Path move(Path source,Path target,CopyOption... options)throws IOException

moveメソッドで、ファイルの移動を行うサンプルです。

package test1;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;

public class Test1 {
	public static void main(String[] args) {

        Path from1 = Paths.get("D:\\Test3","test1.txt");
        Path to1 = Paths.get("D:\\Test4","test1.txt");
		
        try {
			Files.move(from1, to1);
		} catch (IOException e) {
			e.printStackTrace();
		}
 	}
}

14行目は、moveメソッドでTest3フォルダのtest1.txtをTest4フォルダ配下へ移動させています。
移動前に、D:\Test4\test1.txtが存在しているとエラーになります。
java.nio.file.FileAlreadyExistsException

ファイル名を変更する(move)

public static Path move(Path source,Path target,CopyOption... options)throws IOException

moveメソッドで、ファイル名を変更するサンプルです。

package test1;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;

public class Test1 {
	public static void main(String[] args) {

        Path from1 = Paths.get("D:\\Test3","test1.txt");
        Path to1 = Paths.get("D:\\Test3","test100.txt");
		
        try {
			Files.move(from1, to1);
		} catch (IOException e) {
			e.printStackTrace();
		}
 	}
}

14行目は、Test3フォルダ配下のTest1.txtをTest100.txtというファイル名に変更しています。

空ファイルを作成する(createFile)

public static Path createFile(Path path,FileAttribute<?>... attrs) throws IOException

createFileメソッドで、空ファイルを作成するサンプルです。

package test1;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
 
public class Test1 {
    public static void main(String[] args) {
    	
    	Path path1 = Paths.get("D:\\Test3","test1.txt");
    	
        try {
            if (!Files.exists(path1)) {
                Files.createFile(path1);
            }
		} catch (IOException e) {
			e.printStackTrace();
		}
    }
}

13行目は、existsメソッドと否定(!)で指定のファイルが存在していないことを確認しています。
14行目は、createFileメソッドで空ファイルを作成しています。
空ファイル作成時に、ファイルがすでに存在する場合は失敗します。

ファイルを削除する(deleteIfExists)

public static boolean deleteIfExists(Path path) throws IOException

deleteIfExistsメソッドで、ファイルを削除するサンプルです。

package test1;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
 
public class Test1 {
    public static void main(String[] args) {
    	
    	Path path1 = Paths.get("D:\\Test3","test1.txt");
    	
        try {
            Files.deleteIfExists(path1);
		} catch (IOException e) {
			e.printStackTrace();
		}
    }
}

13行目は、deleteIfExistsメソッドで指定のファイルが存在しているか確認し、存在する場合削除します。

ファイルのサイズを取得する(size)

public static long size(Path path) throws IOException

sizeメソッドで、ファイルのサイズを取得するサンプルです。

package test1;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
 
public class Test1 {
    public static void main(String[] args) {
    	
    	Path path1 = Paths.get("D:\\Test1","test1.txt");
    	long size1 = 0;
    	
        try {
        	size1 = Files.size(path1);
        	System.out.println(size1);
		} catch (IOException e) {
			e.printStackTrace();
		}
    }
}

sizeメソッドは、バイト単位でサイズを取得します。

作成日時と更新日時を取得(readAttributes)

public static <A extends BasicFileAttributes> A readAttributes(Path path,Class<A> type,LinkOption... options)throws IOException

readAttributesメソッドで、ファイルの作成日時と更新日時を取得するサンプルです。

package test1;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.attribute.BasicFileAttributes;
import java.nio.file.attribute.FileTime;
import java.text.SimpleDateFormat;
import java.util.Date;

public class Test1 {
	public static void main(String[] args) {
			Path path1 = Paths.get("D:\\Test3","test1.txt");
			
			BasicFileAttributes ba1;
			try {
				ba1 = Files.readAttributes(path1, BasicFileAttributes.class);
	            System.out.println(ba1.creationTime()); //2019-11-16T09:05:46.417019Z
	            System.out.println(ba1.lastModifiedTime());//2019-11-16T09:12:56.74086Z
	            getFormat1(ba1);
			} catch (IOException e) {
				e.printStackTrace();
			}
 	}
	private static void getFormat1(BasicFileAttributes ba1) {
		FileTime time1 = ba1.creationTime();
		FileTime time2 = ba1.lastModifiedTime(); 
		String pattern1 = "yyyy-MM-dd HH:mm:ss";
		
		SimpleDateFormat format1 = new SimpleDateFormat(pattern1);
		String f1 = format1.format(new Date(time1.toMillis()));
		String f2 = format1.format(new Date(time2.toMillis()));
		System.out.println("作成日時 " + f1); //作成日時 2019-11-16 18:05:46
		System.out.println("更新日時 " + f2); //更新日時 2019-11-16 18:12:56
	}
}

13行目は、対象のファイルです。
17行目は、FilesクラスのreadAttributesメソッドでファイルの属性を読み取ります。
18行目は、作成日時ですがフォーマットされていない状態です。
19行目も、更新日時ですがフォーマットされていない状態です。
25~34行目は、SimpleDateFormatクラスを使用してyyyy-MM-dd HH:mm:ssで表示されるようにしています。

一時ファイルを作成する(createTempFile)

public static Path createTempFile(Path dir,String prefix,String suffix,FileAttribute<?>... attrs)throws IOException

createTempFileメソッドで、一時ファイルを作成するサンプルです。

package test1;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
 
public class Test1 {
    public static void main(String[] args) {
    	
		Path path1 = Paths.get("D:\\Test3");

        try {
        	Path test1 = Files.createTempFile(path1,"abc","zzz");
            System.out.println(test1 .toString());
		} catch (IOException e) {
			e.printStackTrace();
		}
    }
}

13行目は、createTempFileメソッドで一時ファイルを作成しています。2つめの引数がプレフィックス(ファイルの先頭につく文字)で3つめの引数がサフィックス(ファイルの最後につく文字)です。
このファイルは自動で削除されません。

以下は、上記コードを5回実行した状態です。5つのファイルが作成されています。

NIO.2のFilesクラス

public final class Files extends Object
  • ファイルを操作するクラスです。
  • Java7で導入された、java.nio.file.Filesクラスです。NIO.2の機能のひとつです。
  • 似た名前でFileクラス(java.io.File)がありますがそれとは別です。
  • 以下はJava8 API仕様のFilesクラスのリンクです。
    https://docs.oracle.com/javase/jp/8/docs/api/java/nio/file/Files.html

メソッドの引数に指定するPathオブジェクト

1 public static Path get(URI uri)
2 public static Path get(String first,String... more)
  • PathオブジェクトはFilesクラスのメソッドの引数に指定します。
  • PathオブジェクトはPathクラスのgetメソッドで取得します。
  • 1は、引数にパスをセットします。
  • 2は、引数にパスとファイル名をセットします。
  • 以下はJava8 API仕様のPathsクラスのリンクです。
    https://docs.oracle.com/javase/jp/8/docs/api/java/nio/file/Paths.html

関連の記事

Java テキストファイルの読み書き(NIO.2のFiles)
Java フォルダの存在/移動/コピー/削除(NIO.2のFiles)

△上に戻る