
Может ли объект
Fileсоответствовать файлу, которого еще нет?Да, если передать в конструктор значение директории.
String dirPath = "/"; File f = new File(dirPath); File[] files = f.listFiles();Так делают, например, для того, чтобы получить массив файлов.
public class MyClass { public static void main(String[] args) { boolean isObject = false; File file = new File("/"); if (file instanceof Object){ isObject = true; } boolean isFile = file.isFile(); // Tests whether the file denoted by this abstract pathname is a normal file. Это из документации System.out.println(isObject + " "+ isFile); } }Вывод:
true falseFileнаследуется отobject. Ответ: да! Жду комментариев.Как преобразовать объект
Fileк типуPath?Метод
toPath();toPath(); //Returns a java.nio.file.Path object constructed from the this abstract path.Зачем нужен класс Files?
Взяли за основу класс
File, добавили в него немного нового, переименовывали методы, а в конце еще и разделили на два. Так что теперь есть два новых класса –PathиFiles.Path– это, фактически новый аналог классаFile, аFiles– это утилитный класс (по аналогии с классамиArrays&Collections), в него вынесли все статические методы классаFile. Так «правильнее» с точки зрения ООП.MНемного из документов:
public final class Files
extends ObjectThis class consists exclusively of static methods that operate on files, directories, or other types of files.
In most cases, the methods defined here will delegate to the associated file system provider to perform the file operations.Какие классы для архивации вы знаете?
Неплохая статья на эту тему и выдержка из нее: Архивация в Java
Для работы с архивами в спецификации Java существуют два пакета –
java.util.zipиjava.util.jarсоответственно для архивов zip и jar. Различие форматов jar и zip заключается только в расширении архива zip. Пакетjava.util.jarаналогичен пакетуjava.util.zip, за исключением реализации конструкторов и методаvoidputNextEntry(ZipEntry e)классаJarOutputStream. Ниже будет рассмотрен только пакетjava.util.jar. Чтобы переделать все примеры на использование zip-архива, достаточно всюду в коде заменить Jar на Zip.Как добавить директорию в архив?
Для себя я понял этот вопрос, как добавление пустой директории в готовый архив. Никаких рабочих примеров я не нашел. Вот код: (Он наглядно показывает, что можно в архив положить любой файл, а вот с пустой директорией… я не знаю как ответить, постить на StackOverFlow не стал, за такой вопрос заминусят точно) Если у кого есть предложения, то напишите.
public class Main { public static void main(String[] args) { String[] myFiles = {"D:\\forJava\\MyArtifactName\\packForTest\\res2.txt", "D:\\forJava\\MyArtifactName\\packForTest\\res.txt", "D:\\forJava\\MyArtifactName\\packForTest\\res4.txt", "D:\\forJava\\MyArtifactName\\packForTest\\testDir\\" }; String zipFile = "D:\\forJava\\MyArtifactName\\packForTest\\res.zip"; ZipUtility zipUtil = new ZipUtility(); try { zipUtil.zip(myFiles, zipFile); } catch (Exception ex) { // some errors occurred ex.printStackTrace(); } } }Вопрос о последней testDir, ее то как раз в получившийся архив JVM не кладет, со всеми остальными txt – файлами норм получается.
ZipUtility.java:import java.io.BufferedInputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.util.ArrayList; import java.util.List; import java.util.zip.ZipEntry; import java.util.zip.ZipOutputStream; public class ZipUtility { private static final int BUFFER_SIZE = 4096; public void zip(List<File> listFiles, String destZipFile) throws IOException { ZipOutputStream zos = new ZipOutputStream(new FileOutputStream(destZipFile)); for (File file : listFiles) { if (file.isDirectory()) { zipDirectory(file, file.getName(), zos); } else { zipFile(file, zos); } } zos.flush(); zos.close(); } public void zip(String[] files, String destZipFile) throws IOException { List<File> listFiles = new ArrayList<File>(); for (int i = 0; i < files.length; i++) { listFiles.add(new File(files[i])); } zip(listFiles, destZipFile); } private void zipDirectory(File folder, String parentFolder, ZipOutputStream zos) throws IOException { for (File file : folder.listFiles()) { if (file.isDirectory()) { zipDirectory(file, parentFolder + "/" + file.getName(), zos); continue; } zos.putNextEntry(new ZipEntry(parentFolder + "/" + file.getName())); BufferedInputStream bis = new BufferedInputStream( new FileInputStream(file)); long bytesRead = 0; byte[] bytesIn = new byte[BUFFER_SIZE]; int read = 0; while ((read = bis.read(bytesIn)) != -1) { zos.write(bytesIn, 0, read); bytesRead += read; } zos.closeEntry(); } } private void zipFile(File file, ZipOutputStream zos) throws IOException { zos.putNextEntry(new ZipEntry(file.getName())); BufferedInputStream bis = new BufferedInputStream(new FileInputStream( file)); long bytesRead = 0; byte[] bytesIn = new byte[BUFFER_SIZE]; int read = 0; while ((read = bis.read(bytesIn)) != -1) { zos.write(bytesIn, 0, read); bytesRead += read; } zos.closeEntry(); } }Код отсюда
Зачем нужны
Properties?Properties– это файл свойств. Структура его: ключ – значение. Для работы с такими файлами в Java есть классProperties, он унаследован отHashTable<Object, Object>Есть статья про манипуляции с ним — Java Properties file examples
В каком виде хранятся данные в файле
.properties?Ключ – значение.
Можно ли изменять данные в объекте
Propertiesпосле загрузки их из файла?Если он унаследован от
HashMap, тогда можно, только потом нужно будет изменения в этот файл отписать. Для этого есть методsetProperty.Вот код:
import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.util.Properties; /** * Created by Роман on 12.09.2016. */ public class LoadAndSetProperties { public static void main(String[] args) { Properties prop = new Properties(); InputStream input = null; try { input = new FileInputStream("D:\\forJava\\MyArtifactName\\packForTest\\config.properties"); // load a properties file prop.load(input); // get the property value and print it out prop.setProperty("database", "ddfdfdfdfdf"); System.out.print(prop.getProperty("database")); } catch (IOException ex) { ex.printStackTrace(); } finally { if (input != null) { try { input.close(); } catch (IOException e) { e.printStackTrace(); } } } } }Вывод:
ddfdfdfdfdfЗачем нужен класс
FileReader?Java Docs:
public class FileReader
extends InputStreamReaderConvenience class for reading character files. The constructors of this class assume that the default character encoding and the default byte-buffer size are appropriate. To specify these values yourself, construct an InputStreamReader on a FileInputStream.
FileReader is meant for reading streams of characters.
Класс для чтения символов файлов. Конструкторы этого класса предполагают, что кодировка символов дефолтная и дефолтный размер буфера являются подходящими. Чтобы задать эти значения самостоятельно, следует построить
InputStreamReaderнадFileInputStream.FileReaderпредназначен для считывания потоков символов.Зачем нужен класс
FileWriter?public class FileWriter
extends OutputStreamWriterConvenience class for writing character files. The constructors of this class assume that the default character encoding and the default byte-buffer size are acceptable. To specify these values yourself, construct an OutputStreamWriter on a FileOutputStream.
Whether or not a file is available or may be created depends upon the underlying platform. Some platforms, in particular, allow a file to be opened for writing by only one FileWriter (or other file-writing object) at a time. In such situations the constructors in this class will fail if the file involved is already open. FileWriter is meant for writing streams of characters.
Класс для записи символов файлов. Конструкторы этого класса предполагают, что кодировка символов дефолтная и дефолтный размер буфера являются приемлемым. Чтобы задать эти значения самостоятельно, следует построить
OutputStreamWriterнадFileOutputStream. Является ли файл доступен для записи, зависит от используемой платформы. Некоторые платформы разрешают держать файл для записи только однимFileWriter(или другого объекта записи файла), в одно время.FileWriterпредназначен для записи потоков символов. Для написания потоков необработанных байтов, используйтеFileOutputStream.Эти классы (
FileReaderиFileWriter) специально ориентированы для работы с текстом и строками.
ПЕРЕЙДИТЕ В ПОЛНУЮ ВЕРСИЮ
Чтобы сохранить добавленное/измененное свойство в файле(а в этом как раз и весь смысл ибо сейчас свойство есть лишь в runtime) добавьте
prop.store(new FileOutputStream(«D:\\forJava\\MyArtifactName\\packForTest\\config.properties»), «comments»);
Для упаковки директории необходимо выбрать способ обхода файлов директории со всеми ее поддиректориями. Например, с помощью интерфейса FileVisitor, воспользоваться очередью или рекурсией.
при создании ZipEntry используется относительный путь, а не просто имя файла. Это сделано для того, чтобы при архивации сохранились все дерево директорий. В случае использования f.getName() в архиве просто будет плоский список файлов без информации о директориях.
Объект класса File является абстрактным представлением файла и пути к нему. Он устанавливает только соответствие с ним, при этом для создания объекта неважно, существует ли такой файл на диске. После создания можно выполнить проверку, вызвав метод exists, который возвращает значение true, если файл существует. Создание или удаление объекта класса File никоим образом не отображается на реальных файлах. Для работы с содержимым файла можно получить экземпляры File I/O Stream.
Объект File может указывать на каталог (узнать это можно путем вызова метода isDirectory ). Метод list возвращает список имен (массив String ) содержащихся в нем файлов (если объект File не указывает на каталог – будет возвращен null ).
Нашел такое: stackoverflow.com/questions/740375/directories-in-a-zip-file-when-using-java-util-zip-zipoutputstream
ZipOutputStream zos = new ZipOutputStream(new FileOutputStream(«C:/1/1.zip»));
zos.putNextEntry(new ZipEntry(«1/»));
Будет архив с пустой папкой «1».
А если директория с файлом:
zos.putNextEntry(new ZipEntry(«1/1.txt»));
Files.copy(Paths.get(«C:/1/1.txt»), zos);
Совсем не смог понять суть приведенного вами ответа. Согласно документации, я это все вижу так:
1. В конструктор мы передаем имя файла.
2. Существование файла можем проверить с помощью метода или попытаться создать файл методом