
要使用 std::filesystem 库操作文件和目录,你需要确保编译器支持 C++17 及以上标准。这个库提供了简洁直观的接口来处理路径、文件属性、创建/删除目录、遍历目录等常见操作。
启用 std::filesystem
在代码中包含头文件:#include
namespace fs = std::filesystem;
- GCC/Clang: 添加 -std=c++17 参数
- 示例命令:g++ -std=c++17 main.cpp -o main
路径操作:fs::path
std::filesystem 的核心是 fs::path 类,用于表示和操作路径。常用方法包括:
立即学习“C++免费学习笔记(深入)”;
-
拼接路径:使用 / 操作符
fs::path p = "/home/user"; p /= "docs"; p += ".txt"; // 结果: /home/user/docs.txt -
获取路径组件:
p.parent_path()→ 目录部分p.filename()→ 文件名(含扩展名)p.stem()→ 文件名不含扩展p.extension()→ 扩展名(如 .cpp) -
判断路径类型:
p.has_extension()、p.is_absolute()等
文件与目录基本操作
检查文件或目录是否存在,并进行创建、删除等操作。-
检查存在性:
if (fs::exists("test_dir")) { ... } -
判断是否为目录:
if (fs::is_directory("test_dir")) { ... } -
创建目录:
fs::create_directory("new_folder");(仅创建一级)fs::create_directories("a/b/c");(递归创建多级目录) -
删除文件或目录:
fs::remove("file.txt");(删除单个)fs::remove_all("folder");(递归删除整个目录)
遍历目录内容
使用 fs::directory_iterator 遍历目录中的每一项。示例:打印当前目录下所有条目
for (const auto& entry : fs::directory_iterator(".")) {
if (entry.is_regular_file()) {
std::cout << "[文件] " << entry.path().filename() << "\n";
} else if (entry.is_directory()) {
std::cout << "[目录] " << entry.path().filename() << "\n";
}
}
若需要递归遍历子目录,使用 fs::recursive_directory_iterator:
for (const auto& entry : fs::recursive_directory_iterator("my_project")) {
std::cout << entry.path() << "\n";
}
获取文件信息
可以查询文件大小、最后修改时间等元数据。-
获取文件大小:
uintmax_t size = fs::file_size("data.bin"); -
获取最后修改时间:
auto time = fs::last_write_time("config.json");
返回的是file_time_type,可通过转换输出人类可读时间(需 chrono 配合)
重命名与复制文件
-
重命名或移动文件:
fs::rename("old.txt", "new.txt"); -
复制文件:
fs::copy("source.txt", "backup.txt");
支持选项如fs::copy_options::overwrite_existing











