递归方式创建目录树(多级目录)

本文提供了一个用C++实现的递归创建多级目录的方法。该方法适用于需要在不存在的路径中创建完整目录结构的场景,通过递归回溯确保每个级别的目录都能被正确创建。

好像系统只提供了创建目录函数,但一次创建多级目录的函数没找到,所以自己写了一个,仅供参考。

本代码基于 C++ Builder


void __fastcall MakeDirectory(AnsiString Dir) // 创建复目录
{
 // 递归创建多级目录
 // 当创建某一级目录失败后,退一级目录,再创建目录,以此类推,直到创建目录成功,并依次退出递归,并将上一次创建失败的目录创建完成

 // 非多级目录形式
 if(Dir.Length() <= 3)
 {
  return;
 }

 // 路径形式改为目录形式
 if(Dir[Dir.Length()] == '\\')   // 将路径改为目录
 {
  Dir.Delete(Dir.Length(), 1);
 }

 // 修改文件属性
 WIN32_FIND_DATA wfd;
 HANDLE hFind=FindFirstFile(Dir.c_str(), &wfd); // 查找
 if(hFind != INVALID_HANDLE_VALUE)
 {
  FindClose(hFind);

  if(wfd.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)
   return;
 }

 // 创建当前目录的地目录失败
 if(CreateDir(Dir) == false)
 {
  // 退一级目录
  AnsiString NewDir = Dir;
  while(NewDir[NewDir.Length()] != '\\')     // 撤到当前目录的上一个目录
  {
   NewDir.Delete(NewDir.Length(), 1);
  }
  // 删除符号 \\
  NewDir.Delete(NewDir.Length(), 1); // 将 // 也删除

  // 递归进入
  MakeDirectory(NewDir);  // 递归本函数,再创建目录
  // 递归退出后创建之前失败的目录
  CreateDir(Dir);  // 递归返回,在存在的目录上再建目录
 }
// 完成后,目录树建立成功。
}
//---------------------------------------------------------------------------

 

### 创建目录树递归方法 在编程中,可以通过递归方式构建和创建目录树结构。这种方法的核心在于将当前节点视为根节点,并对其子节点逐一调用相同的函数来完成整个层次结构的建立。 以下是基于 Python 的一种实现方案: #### 使用 `os` 和 `pathlib` 模块 Python 提供了标准库模块 `os` 和更现代的 `pathlib` 来处理文件路径操作。可以利用这些工具递归创建多级目录。 ```python import os def create_directory_tree(base_path, structure): """ 递归创建目录树。 参数: base_path (str): 基础路径。 structure (dict): 表示目录结构的嵌套字典。 """ for directory, sub_structure in structure.items(): full_path = os.path.join(base_path, directory) os.makedirs(full_path, exist_ok=True) # 创建目录并允许已存在时不报错[^1] if isinstance(sub_structure, dict) and sub_structure: # 如果有子目录,则继续递归 create_directory_tree(full_path, sub_structure) # 定义目录结构 directory_structure = { 'folder1': { 'subfolder1_1': {}, 'subfolder1_2': {} }, 'folder2': { 'subfolder2_1': { 'deep_subfolder2_1_1': {} } } } base_dir = './my_project' # 设置基础路径 create_directory_tree(base_dir, directory_structure) ``` 上述代码定义了一个名为 `create_directory_tree` 的函数,该函数接受两个参数:一个是基础路径 (`base_path`);另一个是一个表示目录结构的嵌套字典 (`structure`)。对于每一层的键值对,它会尝试创建对应的目录,并在其内部进一步应用相同逻辑直至最深层结束[^2]。 #### 关于异常处理 需要注意的是,在实际开发过程中可能遇到权限不足等问题导致无法成功创建某些特定位置下的文件夹。因此建议加入适当的错误捕获机制以便更好地管理潜在风险情况的发生。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值