C++ SHFileOperation实现文件、文件夹拷贝、删除、重命名

本文介绍了使用Windows API函数SHFileOperation进行文件拷贝(FastCopyFile)、重命名(RenameFile)以及目录复制(CopyDirectory)的方法,包括异常处理和参数检查。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    /// <summary>
    /// 拷贝文件
    /// </summary>
    /// <param name="srcFile"></param>
    /// <param name="destFile"></param>
    /// <returns></returns>
    int FastCopyFile(const char* srcFile, const char* destFile) {
        if (nullptr == srcFile || nullptr == destFile)
        {
            return -1;
        }
        try
        {
            //文件复制,路径必须以"\0"即空为结尾
            std::string src = srcFile + '\0\0';
            std::string dest = destFile + '\0\0';
            SHFILEOPSTRUCTA fop;
            ZeroMemory(&fop, sizeof fop);
            fop.wFunc = FO_COPY;
            fop.pFrom = src.c_str();
            fop.pTo = dest.c_str();
            //不显示提示或错误对话框
            fop.fFlags = FOF_SILENT | FOF_NOCONFIRMATION | FOF_NOERRORUI | FOF_NOCONFIRMMKDIR;
            int ret = SHFileOperationA(&fop);
            return ret;
        }
        catch (const std::exception&)
        {
            return -1;
        }
    }

    /// <summary>
    /// 重命名文件
    /// </summary>
    /// <param name="srcFile"></param>
    /// <param name="destFile"></param>
    /// <returns></returns>
    int RenameFile(char* srcFile, char* destFile) {
        if (nullptr == srcFile || nullptr == destFile)
        {
            return -1;
        }
        try
        {
            SHFILEOPSTRUCTA fop;
            ZeroMemory(&fop, sizeof fop);
            fop.wFunc = FO_RENAME;
            fop.pFrom = srcFile;
            fop.pTo = destFile;
            //不显示提示或错误对话框
            fop.fFlags = FOF_SILENT | FOF_NOCONFIRMATION | FOF_NOERRORUI | FOF_NOCONFIRMMKDIR;
            int ret = SHFileOperationA(&fop);
            return ret;
        }
        catch (const std::exception&)
        {
            return -1;
        }
    }

    /// <summary>
    /// 拷贝文件夹,包含文件
    /// </summary>
    /// <param name="srcDir"></param>
    /// <param name="destDir"></param>
    /// <returns></returns>
    int CopyDirectory(const char* srcDir, const char* destDir) {
        if (nullptr == srcDir || nullptr == destDir)
        {
            return -1;
        }

        try
        {
            HANDLE hFile;

            WIN32_FIND_DATAA wfd; //数据结构;
            char sz_path[MAX_PATH] = { 0 };
            char buf[MAX_PATH * 2] = { 0 };
            char fileName[MAX_PATH] = { 0 };
            char temp[MAX_PATH] = { 0 };//临时数组;
            char parseFileName[MAX_PATH] = { 0 };

            strcpy_s(sz_path, srcDir);
            strcat_s(sz_path, "\\*.*"); //匹配任何文件包括文件夹目录;
            hFile = FindFirstFileA(sz_path, &wfd);

            if (hFile != INVALID_HANDLE_VALUE)
            {
                do
                {
                    if (wfd.cFileName[0] == '.') //如果是.或..则过滤;
                        continue;
                    else if (wfd.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) //如果是目录则递归;
                    {
                        strcpy_s(sz_path, srcDir);
                        strcat_s(sz_path, "\\");
                        strcat_s(sz_path, wfd.cFileName);    //拼接目录全路径名;
                        FastCopyFile(sz_path, destDir);
                    }
                    else
                    {
                        strcpy_s(sz_path, srcDir);
                        strcat_s(sz_path, "\\");
                        strcat_s(sz_path, wfd.cFileName);    //拼接目录全路径名;
                        FastCopyFile(sz_path, destDir);
                    }
                } while (FindNextFileA(hFile, &wfd));
            }

            return 0;
        }
        catch (const std::exception&)
        {
            return -1;
        }
    }

关于SHFileOperation函数的补充

 

API功能详解: 使用API函数SHFileOperation,这个函数可以同时拷贝删除、改名或移动多个文件,甚至整个目录。如果你愿意,还可以显示相应的动画对话框,功能十分强大。SHFileOperation的参数是一个SHFILEOPSSTRUCT结构。这个结构中各成员的含义如下: - hwnd - 显示文件操作对话框的窗口句柄 - wFunc - 表示要进行的操作,可以取以下值: - FO_COPY - 拷贝文件。所要拷贝文件由pFrom成员指定,目的地址有pTo成员指定。 - FO_DELETE - 删除pFrom指定的文件。(pTo 被忽略。) - FO_MOVE - 移动文件。所要移动的文件由pFrom成员指定,目的地址有pTo成员指定。 - FO_RENAME - 改名pFrom指定的文件。 - pFrom - 指定文件名的缓冲区的地址。必须以Chr(0)结尾。如果包括多个文件以Chr(0)分割。 - pTo - 指定目的文件名或目录的缓冲区的地址。必须以Chr(0)结尾。如果使用了FOF_MULTIDESTFILES标志,可以包括多个文件名,文件名之间以Chr(0)分割。 - fFlags - 标志: - FOF_ALLOWUNDO - 允许恢复 - FOF_FILESONLY - 如果使用了*.*,只操作文件。 - FOF_MULTIDESTFILES - pTo成员可以为多个目的文件。 - FOF_NOCONFIRMATION - 不显示确认对话框。 - FOF_NOCONFIRMMKDIR - 不确认是否建立目录。 - FOF_NOERRORUI - 如果有错误,不显示用户界面。 - FOF_RENAMEONCOLLISION - 如果目的文件已经存在,给要处理的文件一个新名字。 - FOF_SILENT - 不显示进度对话框。 - FOF_SIMPLEPROGRESS - 显示进度框,但不显示文件名。 - fAnyOperationsAborted -如果用户退出,该成员为TRUE,否则为FALSE。 - lpszProgressTitle - 进度框的标题,只有选择了FOF_SIMPLEPROGRESS标志才有效。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值