An open API service indexing awesome lists of open source software.

https://github.com/newyaroslav/banana-filesystem-cpp

Простая С++ библиотека для работы с файловой системой
https://github.com/newyaroslav/banana-filesystem-cpp

check-file cpp cpp11 create-directory directories directory file file-library file-list file-name file-size file-system filesystem load-file remove-directory save-files

Last synced: 3 months ago
JSON representation

Простая С++ библиотека для работы с файловой системой

Awesome Lists containing this project

README

        

### banana-filesystem-cpp
Простая header-only С++ библиотека для работы с файловой системой

### Как пользоваться?

* Получить директорию исполняемого файла

```C++
#include

//...

// выведем в консоль директорию исполняемого файла
cout << bf::get_current_work_dir() << endl;

```

* Проверить наличие файла

```C++

if(check_file("text.txt")) {
// файл существует
} else {
// файла нет
}

```

* Получить список файлов (или папок)

```C++

std::vector list_files; // список файлов и прочего
/* чтобы получить список файлов только в директории "..//..//"
* имена файлов будут без пути "..//..//"
* например: "test.txt" "test2.txt"
*/
bf::get_list_files("..//..//", list_files, false);

/* чтобы получить список файлов не только в директории "..//..//"
* но и во всех вложенных папках. Все имена файлов будут начинаться с указанного пути
* например: "..//..//test.txt" "..//..//test2.txt" "..//..//folder//test3.txt" "..//..//folder2//test4.txt"
* bf::get_list_files("..//..//", list_files);
* чтобы получить список только папок, и не только в директории "..//..//"
* но и во всех вложенных папках. Все имена папок будут начинаться с указанного пути
* например: "..//..//folder//test3.txt" "..//..//folder2//test4.txt"
* bf::get_list_files("..//..//", list_files, true, true);
*/

// выводим список
for(size_t i = 0; i < list_files.size(); ++i) {
std::cout << list_files[i] << std::endl;
}

```

* Разобрать путь на составляющие

```C++

string path = "C:/Users\\user/Downloads";

std::vector list_dir;
bf::parse_path(path, list_dir);

for( auto & p : list_dir ) cout << "-> " << p << endl;

/* на экране будет выведено
* -> C:
* -> Users
* -> user
* -> Downloads
*/

```

* Получить расширение файла и установить новое расширение

```C++

string path = "C:/Users\\user/Downloads\\test.dat";
// На экран выведет .dat
std::cout << "file extension (for path): " << bf::get_file_extension(path) << endl;
// На экран выведет C:/Users/user/Downloads/test.test
std::cout << "set file extension (for path): " << bf::set_file_extension(path, ".test") << endl;

```

* Создать директорию

```C++

bf::create_directory("..//..//test//test2//test3");

```

* Удалить директорию

```C++

/* Данная функция удаляет директорию со всеми в ней файлами и папками
* если параметр is_delete_root_directory true, функция удаляет также корневой каталог (который первым указан в path)
* иначе функция оставляет паку
*/
bf::remove_directory("..\\..\\test", true);

```

* Получить размер файла

```C++

int file_size = bf::get_file_size("test.txt");
if(file_size >= 0) {
// файл существует и его размер получен
}

```

* Читать файл целиком в std::string

```C++

std::string file_data;
int file_size = bf::load_file("test.txt", file_data);
if(file_size >= 0) {
// файл существует и его размер получен
}

```