Difference between revisions of "JAVA: File Class"

From OnnoWiki
Jump to navigation Jump to search
Line 1: Line 1:
The File class is Java’s representation of a file or directory pathname. Because file and directory names have different formats on different platforms, a simple string is not adequate to name them. The File class contains several methods for working with the pathname, deleting and renaming files, creating new directories, listing the contents of a directory, and determining several common attributes of files and directories.  
+
Class File adalah representasi Java dari pathname file atau direktori. Karena nama file dan direktori memiliki format yang berbeda pada platform yang berbeda, string sederhana tidak cukup untuk menamainya. Class File berisi beberapa method untuk bekerja dengan pathname, menghapus dan mengganti nama file, membuat direktori baru, membuat daftar isi direktori, dan menentukan beberapa atribut umum dari file dan direktori.
  
Kelas File adalah representasi Java dari nama path file atau direktori. Karena nama file dan direktori memiliki format yang berbeda pada platform yang berbeda, string sederhana tidak cukup untuk menamainya. Kelas File berisi beberapa metode untuk bekerja dengan nama path, menghapus dan mengganti nama file, membuat direktori baru, membuat daftar isi direktori, dan menentukan beberapa atribut umum dari file dan direktori.
+
* Ini adalah representasi abstrak dari file dan pathname direktori.
 
+
* pathname, apakah abstrak atau dalam bentuk string dapat berupa absolut atau relatif. Induk dari pathname abstrak dapat diperoleh dengan memanggil metode getParent() dari Class ini.
 
+
* Pertama-tama, kita harus membuat object Class File dengan meneruskan nama file atau nama direktori ke sana. Sistem file dapat menerapkan pembatasan operasi tertentu pada objek sistem file yang sebenarnya, seperti membaca, menulis, dan mengeksekusi. Pembatasan ini secara kolektif dikenal sebagai izin akses.
* It is an abstract representation of files and directory pathnames.
+
* Contoh Class File tidak dapat diubah; yaitu, setelah dibuat, pathname abstrak yang diwakili oleh object File tidak akan pernah berubah.
* A pathname, whether abstract or in string form can be either absolute or relative. The parent of an abstract pathname may be obtained by invoking the getParent() method of this class.
 
* First of all, we should create the File class object by passing the filename or directory name to it. A file system may implement restrictions to certain operations on the actual file-system object, such as reading, writing, and executing. These restrictions are collectively known as access permissions.
 
* Instances of the File class are immutable; that is, once created, the abstract pathname represented by a File object will never change.
 
 
 
* Ini adalah representasi abstrak dari file dan nama path direktori.
 
* Nama path, apakah abstrak atau dalam bentuk string dapat berupa absolut atau relatif. Induk dari nama path abstrak dapat diperoleh dengan memanggil metode getParent() dari kelas ini.
 
* Pertama-tama, kita harus membuat objek kelas File dengan meneruskan nama file atau nama direktori ke sana. Sistem file dapat menerapkan pembatasan operasi tertentu pada objek sistem file yang sebenarnya, seperti membaca, menulis, dan mengeksekusi. Pembatasan ini secara kolektif dikenal sebagai izin akses.
 
* Contoh kelas File tidak dapat diubah; yaitu, setelah dibuat, nama path abstrak yang diwakili oleh objek File tidak akan pernah berubah.
 
  
  
Line 18: Line 10:
 
==Bagaimana cara membuat Object File?==
 
==Bagaimana cara membuat Object File?==
  
A File object is created by passing in a string that represents the name of a file, a String, or another File object. For example,
+
Object File dibuat dengan meneruskan string yang mewakili nama file, String, atau objek File lainnya. Sebagai contoh,
 
 
Objek File dibuat dengan meneruskan string yang mewakili nama file, String, atau objek File lainnya. Sebagai contoh,
 
  
 
  File a = new File("/usr/local/bin/geeks");
 
  File a = new File("/usr/local/bin/geeks");
  
This defines an abstract file name for the geeks file in the directory /usr/local/bin. This is an absolute abstract file name.
+
Ini mendefinisikan nama file abstrak untuk file Geeks di direktori /usr/local/bin. Ini adalah nama file abstrak yang bersifat absolut.
 
 
Ini mendefinisikan nama file abstrak untuk file Geeks di direktori /usr/local/bin. Ini adalah nama file abstrak mutlak.
 
  
  

Revision as of 13:24, 7 May 2022

Class File adalah representasi Java dari pathname file atau direktori. Karena nama file dan direktori memiliki format yang berbeda pada platform yang berbeda, string sederhana tidak cukup untuk menamainya. Class File berisi beberapa method untuk bekerja dengan pathname, menghapus dan mengganti nama file, membuat direktori baru, membuat daftar isi direktori, dan menentukan beberapa atribut umum dari file dan direktori.

  • Ini adalah representasi abstrak dari file dan pathname direktori.
  • pathname, apakah abstrak atau dalam bentuk string dapat berupa absolut atau relatif. Induk dari pathname abstrak dapat diperoleh dengan memanggil metode getParent() dari Class ini.
  • Pertama-tama, kita harus membuat object Class File dengan meneruskan nama file atau nama direktori ke sana. Sistem file dapat menerapkan pembatasan operasi tertentu pada objek sistem file yang sebenarnya, seperti membaca, menulis, dan mengeksekusi. Pembatasan ini secara kolektif dikenal sebagai izin akses.
  • Contoh Class File tidak dapat diubah; yaitu, setelah dibuat, pathname abstrak yang diwakili oleh object File tidak akan pernah berubah.


Bagaimana cara membuat Object File?

Object File dibuat dengan meneruskan string yang mewakili nama file, String, atau objek File lainnya. Sebagai contoh,

File a = new File("/usr/local/bin/geeks");

Ini mendefinisikan nama file abstrak untuk file Geeks di direktori /usr/local/bin. Ini adalah nama file abstrak yang bersifat absolut.


Constructors of File Class

  • File(File parent, String child): Creates a new File instance from a parent abstract pathname and a child pathname string.
  • File(String pathname): Creates a new File instance by converting the given pathname string into an abstract pathname.
  • File(String parent, String child): Creates a new File instance from a parent pathname string and a child pathname string.
  • File(URI uri): Creates a new File instance by converting the given file: URI into an abstract pathname.

Method dari File Class

No.	Method		Description										Return Type
1.	canExecute()	Tests whether the application can execute the file denoted by this abstract pathname.	boolean
2.	canRead()	Tests whether the application can read the file denoted by this abstract pathname.	boolean
3.	canWrite()	Tests whether the application can modify the file denoted by this abstract pathname.	boolean
4.	compareTo(File pathname)	Compares two abstract pathnames lexicographically.			int
5.	createNewFile()	Atomically creates a new, empty file named by this abstract pathname.			boolean
6.	createTempFile(String prefix, String suffix)	Creates an empty file in the default temporary-file directory.	File
7.	delete()	Deletes the file or directory denoted by this abstract pathname.			boolean
8.	equals(Object obj)	Tests this abstract pathname for equality with the given object.		boolean
9.	exists()	Tests whether the file or directory denoted by this abstract pathname exists.		boolean
10.	getAbsolutePath()	 Returns the absolute pathname string of this abstract pathname.		String
11.	list()	Returns an array of strings naming the files and directories in the directory.			String[]
12.	getFreeSpace()	Returns the number of unallocated bytes in the partition.				long
13.	getName()	Returns the name of the file or directory denoted by this abstract pathname.		String
14.	getParent()	Returns the pathname string of this abstract pathname’s parent.				String
15.	getParentFile()	Returns the abstract pathname of this abstract pathname’s parent.			File
16.	getPath()	Converts this abstract pathname into a pathname string.					String
17.	setReadOnly()	Marks the file or directory named so that only read operations are allowed.		boolean
18.	isDirectory()	Tests whether the file denoted by this pathname is a directory.				boolean
19.	isFile()	Tests whether the file denoted by this abstract pathname is a normal file.		boolean
20.	isHidden()	Tests whether the file named by this abstract pathname is a hidden file.		boolean
21.	length()	Returns the length of the file denoted by this abstract pathname.			long
22.	listFiles()	Returns an array of abstract pathnames denoting the files in the directory.		File[]
23.	mkdir()	Creates the directory named by this abstract pathname.						boolean
24.	renameTo(File dest)	Renames the file denoted by this abstract pathname.				boolean
25.	setExecutable(boolean executable)	A convenience method to set the owner’s execute permission.	boolean
26.	setReadable(boolean readable)	A convenience method to set the owner’s read permission.		boolean
27.	setReadable(boolean readable, boolean ownerOnly)	Sets the owner’s or everybody’s read permission.boolean
28.	setWritable(boolean writable)	A convenience method to set the owner’s write permission.		boolean
29.	toString()	Returns the pathname string of this abstract pathname.					String
30.	toURI()		Constructs a file URI that represents this abstract pathname.				URI

Example 1: Program to check if a file or directory physically exists or not.

// In this Java program, we accepts a file or directory name from
// command line arguments. Then the program will check if
// that file or directory physically exist or not and
// it displays the property of that file or directory.
  
import java.io.File;
  
// Displaying file property
class fileProperty {
    public static void main(String[] args)
    {
  
        // accept file name or directory name through
        // command line args
        String fname = args[0];
  
        // pass the filename or directory name to File
        // object
        File f = new File(fname);
  
        // apply File class methods on File object
        System.out.println("File name :" + f.getName());
        System.out.println("Path: " + f.getPath());
        System.out.println("Absolute path:"
                           + f.getAbsolutePath());
        System.out.println("Parent:" + f.getParent());
        System.out.println("Exists :" + f.exists());
  
        if (f.exists()) {
            System.out.println("Is writable:"
                               + f.canWrite());
            System.out.println("Is readable" + f.canRead());
            System.out.println("Is a directory:"
                               + f.isDirectory());
            System.out.println("File Size in bytes "
                               + f.length());
        }
    }
}

Output:

File name :file.txt
Path: file.txt
Absolute path:C:\Users\akki\IdeaProjects\codewriting\src\file.txt
Parent:null
Exists :true
Is writable:true
Is readabletrue
Is a directory:false
File Size in bytes 20

Example 2: Program to display all the contents of a directory

Here we will accept a directory name from the keyboard and then display all the contents of the directory. For this purpose, list() method can be used as:

String arr[]=f.list();

In the preceding statement, the list() method causes all the directory entries copied into the array arr[]. Then pass these array elements arr[i] to the File object and test them to know if they represent a file or directory.

// Java Program to display all 
// the contents of a directory
import java.io.BufferedReader;
import java.io.File;
import java.io.IOException;
import java.io.InputStreamReader;
  
// Displaying the contents of a directory
class Contents {
    public static void main(String[] args)
        throws IOException
    {
        // enter the path and dirname from keyboard
        BufferedReader br = new BufferedReader(
            new InputStreamReader(System.in));
  
        System.out.println("Enter dirpath:");
        String dirpath = br.readLine();
        System.out.println("Enter the dirname");
        String dname = br.readLine();
  
        // create File object with dirpath and dname
        File f = new File(dirpath, dname);
  
        // if directory exists,then
        if (f.exists()) {
            // get the contents into arr[]
            // now arr[i] represent either a File or
            // Directory
            String arr[] = f.list();
  
            // find no. of entries in the directory
            int n = arr.length;
  
            // displaying the entries
            for (int i = 0; i < n; i++) {
                System.out.println(arr[i]);
                // create File object with the entry and
                // test if it is a file or directory
                File f1 = new File(arr[i]);
                if (f1.isFile())
                    System.out.println(": is a file");
                if (f1.isDirectory())
                    System.out.println(": is a directory");
            }
            System.out.println(
                "No of entries in this directory " + n);
        }
        else
            System.out.println("Directory not found");
    }
}

Output:

Enter dirpath:
C:\Users\akki\IdeaProjects\
Enter the dirname
codewriting
.idea
: is a directory
an1.txt
: is a file
codewriting.iml
: is a file
file.txt
: is a file
out
: is a directory
src
: is a directory
text
: is a file
No of entries in this directory 7