0 / 0 / 1
Регистрация: 28.10.2013
Сообщений: 41

Рекурсивный поиск файлов

04.06.2014, 20:56. Показов 2636. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Нужна помощь есть код который вполне подходит мне он ищет диски на компе потом в каждом диске ищет файлы по маске, но никак не могу понять как изменить маску поиска и добавить вывод адреса найденных файлов в текстовый файл. Подскажите пожалуйста что изменить в коде.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
#include <stdio.h>
#include <windows.h>
#include <shlwapi.h>
 
#define EXT_BUFF_SIZE 1024*1024
 
char* szExtBuff;
 
void ParseFile(char* szPathBuff) {
    char* lpExt = szPathBuff + strlen(szPathBuff) - 1;
    while((*lpExt != '.') && (*lpExt != '\\')) lpExt--;
    if(*lpExt == '\\') return; // no extension
 
    if(!StrStrI(szExtBuff, lpExt)) {
        strcat(szExtBuff, ";");
        strcat(szExtBuff, lpExt);
        printf("%s\n", lpExt);
    }
}
 
void SearchRec(PCHAR szPathBuff) {
    PCHAR pLast = szPathBuff + strlen(szPathBuff);
    strcat(szPathBuff, "*");
 
    LPWIN32_FIND_DATA lpFindData = new WIN32_FIND_DATA;
    if(!lpFindData) {
        printf("ALLOCATION FAILED!\n");
        return;
    }
 
    HANDLE hFind = FindFirstFile(szPathBuff, lpFindData);
 
    if(hFind != INVALID_HANDLE_VALUE) {
        do {
            *pLast = '\0';
 
            if(lpFindData->cFileName[0] == '.')
                continue;
 
            strcat(szPathBuff, lpFindData->cFileName);
            if(lpFindData->dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) {
                strcat(szPathBuff, "\\");
                SearchRec(szPathBuff);
            } else {
                // szPathBuff contains full file name
                ParseFile(szPathBuff);
 
                if((EXT_BUFF_SIZE - strlen(szExtBuff)) < 512) {
                    printf("Buffer is full.\n");
                    break;
                }
            }
        } while(FindNextFile(hFind, lpFindData));
 
        FindClose(hFind);
    }
 
    delete lpFindData;
}
 
char szCurrDrive[] = "A:\\";
 
void AllDrivesSearch() {
    CHAR szPathBuff[MAX_PATH];
    DWORD i, dwDisksMask = GetLogicalDrives();
 
    for(i = 0; i < 26; i++) {
        if(dwDisksMask & 1) {
            printf("****************\nSearching on %s\n****************\n", szCurrDrive);
            strcpy(szPathBuff, szCurrDrive);
            SearchRec(szPathBuff);
        }
        dwDisksMask >>= 1;
        szCurrDrive[0]++;
    }
}
 
int main(int argc, char* argv[]) {
    szExtBuff = (char*)malloc(EXT_BUFF_SIZE);
    if(!szExtBuff) {
        printf("malloc() failed.\n");
        return 0;
    }
 
    *szExtBuff = '\0';
    AllDrivesSearch();
    free(szExtBuff);
    system("pause");
    return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.06.2014, 20:56
Ответы с готовыми решениями:

Рекурсивный поиск файлов
Была задача разработать простую функцию, которая по заданной маске ищет все возможные файлы в любой папке ну понятно. ФУнкция работает не...

Рекурсивный поиск файлов
Привет всем! Пишу программу, имеющую функционал поиска файлов по ключевым словам. Для начала написал программу, которая перебирала бы...

Рекурсивный поиск файлов в подкаталогах
В общем имеется программа,которая перед каждым именем файла вставляет его порядковый номер и работает только с одним каталогом. Как сделать...

3
0 / 0 / 1
Регистрация: 28.10.2013
Сообщений: 41
05.06.2014, 21:43  [ТС]
Неужели ни кто не может помощь, ни кто не работал с поиском?
0
Модератор
Эксперт по электронике
8967 / 6733 / 921
Регистрация: 14.02.2011
Сообщений: 23,792
05.06.2014, 21:46
Цитата Сообщение от _666 Посмотреть сообщение
strcat(szPathBuff, "*");
вот это и есть маска "*"
0
0 / 0 / 1
Регистрация: 28.10.2013
Сообщений: 41
05.06.2014, 21:53  [ТС]
Если его поменять на "*.txt" то поиск выдает только первый файл и больше не ищет.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.06.2014, 21:53
Помогаю со студенческими работами здесь

Рекурсивный поиск файлов пропускает UNICODE имена
Помогите, прошу вас! void searchFiles(const char * dirn) { char dirnPath; sprintf(dirnPath, &quot;%s\\*&quot;, dirn); ...

Рекурсивный поиск файлов однозначно должен приводить к краху программы
При поиске файлов в папках и подпапках, всегда в примерах используется метод FindFirstFile, FindNextFile с дальнейшей рекурсией. Есть...

Рекурсивный вывод всех папок и файлов
Господа казалось бы банальный вопрос , но что то я упёрся !!! Вообщем делаю функцию которая показывает все папки и файлы в этих папках ,...

FindFirstFile и FindNextFile рекурсивный поиск файла
Как безопасно (без всевозможных переполнений и высвобождением ресурсов) реализовать рекурсивный поиск файла на одном из разделов диска? Или...

для указанной директории произвести рекурсивный перебор всех вложенных поддиректорий и файлов с занесением результатов в файл
Необходимо разработать приложение (на языке программирования C++), которое позволяет для указанной директории произвести рекурсивный...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

Новые блоги и статьи
EmBitz, создание проекта, отладка, прошивка
locm 15.07.2025
Создание проекта для Blue Pill (STM32F103C8T6) в EmBitz 2. 30, написания кода blink, запуск отладки в ОЗУ, заливка релизной прошивки во flash используя ST-Link и др. . . .
Трассировка корутин Kotlin с OpenTelemetry
mobDevWorks 14.07.2025
Асинхронное программирование меняет правила игры, особенно когда речь заходит о трассировке операций. В Kotlin с его корутинами эта проблема приобретает особый оттенок, который я хотел бы детально. . .
Облачные приложения на Rust: руководство по архитектуре микросервисов
golander 13.07.2025
Когда я впервые взялся за проектирование облачной платформы для одного из наших клиентов, выбор стоял между привычными Go и Java. Но после нескольких месяцев разработки микросервисной системы,. . .
Как Node.js выполняет асинхронные операции
Reangularity 13.07.2025
Каждый раз, когда я рассказываю про Node. js, возникает один и тот же вопрос: "Как эта штука может быть быстрой, если JavaScript — однопоточный язык?" И это действительно кажется парадоксом. Ведь в. . .
Как писать чистый, тестируемый и качественный код на Python
py-thonny 12.07.2025
Помню свой первый проект на Python. Работал тогда быстро, грязно, лишь бы работало. Код был похож на запутанный клубок - переменные по одной букве, функции на 200 строк, комментарии отсутствовали как. . .
Blazor и контроллер сервопривода IoT Meadow Maple
Wired 11.07.2025
Я решил разобраться, как можно соединить современные веб-технологии с миром "железа". Интересная комбинация получилась из Blazor в качестве веб-интерфейса и микроконтроллера Meadow с его веб-сервером. . .
Генерация OpenQASM из кода Q#
EggHead 10.07.2025
Летом 2024-го я начал эксперименты с библиотекой Q# Bridge, и знаете что? Она оказалась просто находкой для тех, кто работает на стыке разных квантовых экосистем. Основная фишка этой библиотеки -. . .
Изучаем новый шаблон ИИ-чата .NET AI Chat Web App
stackOverflow 10.07.2025
В . NET появилось интересное обновление - новый шаблон ИИ-чата под названием . NET AI Chat Web App. Когда я впервые наткнулся на анонс этого шаблона, то сразу понял, что Microsoft наконец-то. . .
Результаты исследования от команды ARP (июль 2025 г.)
Programma_Boinc 10.07.2025
Результаты исследования от команды ARP (июль 2025 г. ) Африканский проект по дождям (ARP) World Community Grid снова запущен! Мы рады поделиться обновленной информацией о нашем прогрессе с осени. . .
Angular vs Svelte - что лучше?
Reangularity 09.07.2025
Сегодня рынок разделился на несколько четких категорий: тяжеловесы корпоративного уровня (Angular), гибкие универсалы (React), прогрессивные решения (Vue) и новая волна компилируемых фреймворков. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru