faustvik/text-files 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

faustvik/text-files

最新稳定版本:v0.0.1

Composer 安装命令:

composer require faustvik/text-files

包简介

Library for working with text files and directory

README 文档

README

Описание

text-files — это мощная библиотека для работы с текстовыми файлами и CSV в PHP. Она предоставляет набор инструментов для управления директориями, файлами, чтения и записи данных, а также обработки CSV файлов. Библиотека включает удобные классы и методы для выполнения различных операций с файловой системой.

Основные возможности

Управление директориями

  • Создание и удаление вложенных директорий.
  • Сканирование директорий и получение информации о файлах.
  • Проверка существования, доступности для чтения и записи файлов.

Работа с файлами

  • Получение информации о файлах (имя, размер, расширение).
  • Проверка доступности для чтения и записи.
  • Блокировка и разблокировка файлов для безопасной многопоточной работы.

Чтение и запись текстовых файлов

  • Чтение файлов в массив строк или одну строку.
  • Запись данных в файл (перезапись или добавление).
  • Пропуск пустых строк при чтении.
  • Преобразование массива данных в JSON перед записью.

Обработка CSV файлов

  • Чтение и запись CSV файлов.
  • Удаление столбцов и строк.
  • Обновление заголовков.
  • Поддержка различных кодировок и настроек CSV (разделители, экранирование и т.д.).

Установка

Для установки библиотеки используйте Composer:

composer require faustvik/text-files

Использование

Работа с директориями

Создание вложенных директорий:

use FaustVik\Files\Helpers\Directory\DirectoryOperation;
$directoryPath = '/path/to/nested/directory';
DirectoryOperation::creatingNestedDirectories($directoryPath);

Удаление директории со всеми вложенными файлами и директориями:
php

use FaustVik\Files\Helpers\Directory\DirectoryOperation;
$directoryPath = '/path/to/nested/directory';
DirectoryOperation::deleteDir($directoryPath);

Получение содержимого директории:

use FaustVik\Files\Helpers\Directory\DirectoryInfo;
use FaustVik\Files\Helpers\Directory\EnumSortDirectory;
$directoryPath = '/path/to/directory';
$contents = DirectoryInfo::scan($directoryPath, EnumSortDirectory::ASC); // Сортировка по возрастанию

Работа с файлами

Получение информации о файле:

use FaustVik\Files\Helpers\File\FileInfo;
$filePath = '/path/to/file.txt';
$name = FileInfo::getName($filePath); // Получение имени файла
$size = FileInfo::getSize($filePath); // Получение размера файла в байтах
$extension = FileInfo::getExtension($filePath); // Получение расширения файла
$isReadable = FileInfo::isReadable($filePath); // Проверка доступности для чтения
$isWritable = FileInfo::isWritable($filePath); // Проверка доступности для записи

Чтение и запись текстовых файлов

Чтение файла в массив строк:

use FaustVik\Files\Text\TextFileManager;
use FaustVik\Files\Contracts\File\FileContract;
use FaustVik\Files\Contracts\Text\TextSettingReaderContract;
$file = new YourFileImplementation('path/to/file.txt');
$settings = new YourSettingsImplementation();
$reader = new TextFileManager($file, $settings);
$arrayContent = $reader->readToArray();

Запись данных в файл:

$success = $reader->overWrite("new content"); // Перезапись содержимого файла
$success = $reader->write("appended content"); // Добавление данных в конец файла
$success = $reader->appendToStartFile("prepended content"); // Добавление данных в начало файла

Обработка CSV файлов

Чтение CSV файла:

use FaustVik\Files\Csv\CsvManager;
use FaustVik\Files\Contracts\Csv\CsvSettingReaderContract;
use FaustVik\Files\Contracts\File\CsvFileContract;
$csvSettings = new CsvSettings();
$csvFile = new CsvFile('/path/to/your/file.csv');
$csvReader = new CsvManager($csvFile, $csvSettings);
$data = $csvReader->read();
print_r($data);

Запись в CSV файл:

$fields = [
['id' => 1, 'name' => 'John', 'age' => 30],
['id' => 2, 'name' => 'Jane', 'age' => 25]
];
$csvReader->write($fields);

Настройки CSV:

$csvSettings = new CsvSettings();
$csvSettings->setSeparator(';');
$csvSettings->setEncoding('UTF-8');
$csvSettings->setEscapeChar('\\');
$csvSettings->setEnclosureChar('"');

Исключения

Библиотека включает пользовательские исключения для обработки ошибок:

DirectoryException: выбрасывается при ошибках, связанных с директориями.
FileNotFoundException: выбрасывается при попытке получить информацию о несуществующем файле.
IsNotResource: выбрасывается при передаче некорректного ресурса (например, не открытого файла).

统计信息

  • 总下载量: 3
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-03-05