巧用find命令删除Linux下乱码文件及文件夹

 

 

文件

在Linux中,每个文件都有一个节点编号,我们可以利用此来搞定乱码,首先查看乱码文件的节点号

ls -i
22413314 12 ?..??mp3

前面的就是节点号了,接下来使用find命令查询并且删除

find -inum 22413314 -delete

-inum指根据节点号查询;-delete顾名思义就是删除操作了。这样就成功删除乱码文件了,值得注意的是,此方法只适用于删除文件或空的文件夹

文件夹

对于文件夹,尤其是非空的文件夹,上面的方法就不适用了,要用到另外的参数来实现,首先相同的是查看乱码文件夹的节点号

ls -i
18612483 瑗块.?.. - Thank you, Love(128kbps) 2011.06.22

接下来使用find命令删除

find -inum 18612483 -exec rm -rf {} \;
find: ./瑗块.?.. - Thank you, Love(128kbps) 2011.06.22: No such file or directory

虽然提示我们找不到此文件或文件夹,但其实已经表明删除了。-exec作用是查找后执行命令,其中{}代表前面查询到的结果,空格+\;是结束符,其它就不说了。-exec后可以跟任何常用命令,因此这方法不但适用于文件夹,文件也可以。

小技巧

怎么批量删除呢?其实很简单,用for就好了

文件

for n in 22413315 22413314;do find -inum $n -delete;done

文件夹

for n in 22413315 22413314;do find -inum $n -exec rm -rf {} \;;done

$n是变量名,与for后面定义的一致,其它没啥好说的,适用其它操作。

后记

不仅仅是删除,其它基本操作如改名、移动、复制等都适用的。

<think>嗯,用户问的是关于使用FATFS读取文件夹下的文件。我需要先回顾一下FATFS的基本知识,确保自己理解正确。FATFS是一个用于嵌入式系统的文件系统模块,支持FAT12、FAT16、FAT32等格式。用户可能是在开发嵌入式系统,比如STM32者其他微控制器,需要访问SD卡者Flash中的文件。 首先,用户可能需要知道如何初始化FATFS,挂载文件系统,打开目录,然后遍历其中的文件。常见的步骤包括使用f_opendir,f_readdir等函数。不过,我需要确认这些函数的具体用法和可能的参数。 接下来,用户可能遇到的一些常见问题,比如目录打开失败,文件读取错误,者内存不足的问题。这时候需要给出一些调试建议,比如检查返回值,确认路径是否正确,是否有足够的堆内存等。 另外,用户可能对性能优化感兴趣,比如如何高效地遍历大量文件者如何处理长文件名。FATFS的配置选项,比如启用LFN(长文件名支持)可能需要更多的内存,这也是需要注意的地方。 还有,不同版本的FATFS可能有不同的函数名称参数,需要指出参考具体的文档版本。比如,有些版本使用FRESULT类型作为返回值,需要检查每个调用的结果是否正确。 可能用户的应用场景是读取传感器数据存储的文件者进行固件升级,所以示例代码需要简洁明了,展示从挂载到读取目录的全过程。同时,提醒关闭目录和卸载文件系统的重要性,避免资源泄漏。 此外,考虑用户可能的开发环境,比如使用STM32CubeIDE者Arduino,可能需要包含特定的头文件,链接正确的库。但为了通用性,示例代码应该保持平台无关,专注于FATFS本身的API调用。 最后,应该总结常见问题,比如路径格式是否正确,是否处理了隐藏文件系统文件,以及如何处理中文文件名等。这些细节在实际开发中容易出错,需要特别强调。</think>以下是通过FATFS文件系统读取文件夹文件的完整技术指南: --- ### 一、FATFS基础配置 #### 1. 系统初始化流程 ```c FATFS fs; // 文件系统对象 FILINFO fno; // 文件信息结构体 DIR dir; // 目录对象 // 挂载文件系统 FRESULT res = f_mount(&fs, "0:", 1); // "0:"表示物理驱动器号 if (res != FR_OK) { printf("挂载失败! 错误码: %d\n", res); return; } ``` #### 2. 关键数据结构 ```c typedef struct { DWORD fsize; // 文件大小 WORD fdate; // 修改日期 WORD ftime; // 修改时间 BYTE fattrib; // 文件属性 TCHAR fname[FF_LFN_BUF + 1]; // 文件名 } FILINFO; ``` --- ### 二、目录遍历实现 #### 1. 基础遍历算法 ```c void list_files(char* path) { FRESULT res = f_opendir(&dir, path); if (res != FR_OK) return; for(;;) { res = f_readdir(&dir, &fno); if (res != FR_OK || fno.fname[0] == 0) break; // 过滤系统文件 if (!(fno.fattrib & AM_HID)) { printf("%s/%s\n", path, fno.fname); } } f_closedir(&dir); } ``` #### 2. 递归遍历实现 ```c void scan_directory(char* path) { list_files(path); // 先处理当前目录 FRESULT res = f_opendir(&dir, path); while(f_readdir(&dir, &fno) == FR_OK && fno.fname[0]) { if (fno.fattrib & AM_DIR) { // 如果是子目录 char new_path[256]; sprintf(new_path, "%s/%s", path, fno.fname); scan_directory(new_path); // 递归调用 } } f_closedir(&dir); } ``` --- ### 三、关键API详解 | 函数 | 参数说明 | 返回值 | 典型应用场景 | |------|----------|--------|--------------| | `f_opendir` | DIR*, const TCHAR* | FRESULT | 打开目录 | | `f_readdir` | DIR*, FILINFO* | FRESULT | 读取目录项 | | `f_closedir` | DIR* | FRESULT | 关闭目录 | | `f_stat` | const TCHAR*, FILINFO* | FRESULT | 获取文件信息 | --- ### 四、性能优化策略 #### 1. 缓存配置优化 ```c // ffconf.h关键配置项 #define FF_USE_LFN 2 // 启用长文件名(0:禁用, 1:静态缓冲, 2:堆分配) #define FF_LFN_UNICODE 1 // 使用Unicode编码 #define FF_MAX_LFN 255 // 最大文件名长度 #define FF_FS_EXFAT 1 // 启用exFAT支持 ``` #### 2. 内存管理技巧 ```c // 自定义内存分配函数(应对FF_USE_LFN=2) void* ff_memalloc(UINT size) { return malloc(size); } void ff_memfree(void* mblock) { free(mblock); } ``` --- ### 五、典型问题解决方案 #### 问题1:中文乱码 **解决方法**: 1. 设置正确编码格式: ```c #define FF_CODE_PAGE 936 // 简体中文代码页 ``` 2. 确保终端支持UTF-8输出 #### 问题2:长路径处理 **安全写法**: ```c char path[FF_MAX_LFN * 2]; // 双倍缓冲 snprintf(path, sizeof(path), "0:/documents/reports"); ``` #### 问题3:多线程访问 ```c // 使用信号量进行资源保护 osSemaphoreId fs_sem; void read_thread() { osSemaphoreWait(fs_sem, osWaitForever); f_opendir(...); // ...操作... osSemaphoreRelease(fs_sem); } ``` --- ### 六、高级应用场景 #### 1. 文件过滤搜索 ```c void find_files(const char* ext) { while(f_readdir(&dir, &fno) == FR_OK) { if(strstr(fno.fname, ext)) { printf("找到文件: %s\n", fno.fname); } } } ``` #### 2. 文件时间排序 ```c // 比较函数 int compare_time(const void* a, const void* b) { FILINFO* fa = (FILINFO*)a; FILINFO* fb = (FILINFO*)b; return (fa->ftime - fb->ftime); } // 排序实现 FILINFO file_list[50]; int count = 0; while(f_readdir(...) && count < 50) { file_list[count++] = fno; } qsort(file_list, count, sizeof(FILINFO), compare_time); ``` --- ### 七、调试技巧 #### 1. 错误代码解析表 | 错误码 | 含义 | 常见原因 | |--------|------|----------| | FR_OK (0) | 成功 | - | | FR_NO_FILE | 文件不存在 | 路径错误 | | FR_DISK_ERR | 磁盘错误 | 物理连接问题 | | FR_NOT_ENABLED | 文件系统未挂载 | 忘记调用f_mount | | FR_INVALID_NAME | 非法文件名 | 包含非法字符如: *?<> | #### 2. 调试输出示例 ```c printf("[DEBUG] 尝试打开目录: %s\n", path); FRESULT res = f_opendir(&dir, path); if(res != FR_OK) { printf("错误! 代码: 0x%02X\n", res); while(1); // 暂停执行 } ``` --- ### 八、跨平台注意事项 | 平台 | 差异点 | 适配方案 | |------|--------|----------| | STM32 | 需要实现diskio.c | 提供底层SPI/SDIO驱动 | | ESP32 | 默认使用VFS | 调用fatfs_vfs_register() | | Linux | 模拟器模式 | 配置FF_FS_REENTRANT | | Windows | 长路径支持 | 启用FF_USE_LFN=2 | --- 通过合理配置FATFS参数并正确使用API,可以实现稳定可靠的目录遍历操作。重点注意:1) 路径格式规范 2) 错误处理完整性 3) 资源释放及时性。建议开发时启用`FF_STR_VOLUME_ID`和`FF_VOLUME_STRS`配置项以增强可移植性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值