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; }
  • 相关阅读:
    每日日报
    剑指 Offer 18. 删除链表的节点(LeetCode)
    java的访问权限
    java从键盘输入
    剑指 Offer 22. 链表中倒数第k个节点(快慢指针)(LeetCode)
    面试题 02.03. 删除中间节点(LeetCode)
    21. 合并两个有序链表(Leetcode)
    计算总线数据传输率
    时钟周期、总线周期(机器周期)区别
    书单(个人)
  • 原文地址:https://www.cnblogs.com/lyggqm/p/5997376.html
Copyright © 2011-2022 走看看