zoukankan      html  css  js  c++  java
  • [windows][C++][库]遍历删除文件夹

    #include"windows.h"
    #include"string.h"
    BOOL IsDirectory(const char *pDir) { char szCurPath[500]; ZeroMemory(szCurPath, 500); sprintf_s(szCurPath, 500, "%s//*", pDir); WIN32_FIND_DATAA FindFileData; ZeroMemory(&FindFileData, sizeof(WIN32_FIND_DATAA)); HANDLE hFile = FindFirstFileA(szCurPath, &FindFileData); /**< find first file by given path. */ if (hFile == INVALID_HANDLE_VALUE) { FindClose(hFile); return FALSE; /** 如果不能找到第一个文件,那么没有目录 */ } else { FindClose(hFile); return TRUE; } } BOOL DeleteDirectory(const char * DirName) { // CFileFind tempFind; //声明一个CFileFind类变量,以用来搜索 char szCurPath[MAX_PATH]; //用于定义搜索格式 _snprintf(szCurPath, MAX_PATH, "%s//*.*", DirName); //匹配格式为*.*,即该目录下的所有文件 WIN32_FIND_DATAA FindFileData; ZeroMemory(&FindFileData, sizeof(WIN32_FIND_DATAA)); HANDLE hFile = FindFirstFileA(szCurPath, &FindFileData); BOOL IsFinded = TRUE; while (IsFinded) { IsFinded = FindNextFileA(hFile, &FindFileData); //递归搜索其他的文件 if (strcmp(FindFileData.cFileName, ".") && strcmp(FindFileData.cFileName, "..")) //如果不是"." ".."目录 { std::string strFileName = ""; strFileName = strFileName + DirName + "//" + FindFileData.cFileName; std::string strTemp; strTemp = strFileName; if (IsDirectory(strFileName.c_str())) //如果是目录,则递归地调用 { printf("目录为:%s/n", strFileName.c_str()); DeleteDirectory(strTemp.c_str()); } else { DeleteFileA(strTemp.c_str()); } } } FindClose(hFile); BOOL bRet = RemoveDirectoryA(DirName); if (bRet == 0) //删除目录 { printf("删除%s目录失败!/n", DirName); return FALSE; } return TRUE; }
  • 相关阅读:
    Sublime_text 3 安装 Package Control
    sql server cross/outer apply 用法
    sql server pivot/unpivot 行列互转
    sql server利用开窗函数over() 进行分组统计
    小记sql server临时表与表变量的区别
    自己实现各种进制相互转换
    我这样理解js里的this
    js 数组去重
    分布式计算
    START法则
  • 原文地址:https://www.cnblogs.com/lyggqm/p/5997376.html
Copyright © 2011-2022 走看看