begin process at 2012 02 13 05:25:17
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Fichiers / Disque

 > NENGINE ( MOTEUR DE RECHERCHE POUR FICHIER ) (UPDATE)

NENGINE ( MOTEUR DE RECHERCHE POUR FICHIER ) (UPDATE)


 Information sur la source

Note :
9 / 10 - par 1 personne
9,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :Fichiers / Disque Classé sous :recherche, fichier, dossier, moteur, windows Niveau :Débutant Date de création :29/10/2003 Date de mise à jour :18/05/2007 01:54:15 Vu / téléchargé :11 584 / 689

Auteur : NitRic

Ecrire un message privé
Site perso
Commentaire sur cette source (3)
Ajouter un commentaire et/ou une note

 Description

NEngine est un simple petit moteur de recherche qui vous permet de faire des recherches soit par date, par taille, par nom de fichier, par ce qu'ils contiennent ou par extension. Dans le moteur j'ai utilisé les fonctions API FindFirstFile(), FindNextFile() et FindClose() pour les recherches ...

Source

  • Exemple, le contenue du fichier main.cpp
  • **************************************************************
  • #include <iostream.h>
  • #include "nengine.h"
  • void NEngine_OnFound(const char *LongFileName, const char *LongPathName, const unsigned long FileSize, const char *ShortFileName, FILETIME CreationTime, FILETIME LastAccessTime, FILETIME LastWriteTime);
  • int main()
  • {
  • DWORD dwStart = 0;
  • DWORD dwEnd = 0;
  • NEnginePref pref;
  • NEngine find;
  • long retval = 0;
  • /* Test, pour récupérer la taille d'un répertoire, fonctionnel à 100%
  • unsigned long size = 0;
  • pref.break_on_error = false;
  • find.SetPref(pref);
  • find.GetDirectorySize("e:\\", size, true);
  • cout << "Directory size: " << size << " bytes\n";
  • return 0;
  • */
  • pref.type = TYPE_BY_DATE;
  • // par date ...
  • // à partir du: 1 août 2003
  • pref.date_min.year = 2003;
  • pref.date_min.month = 8;
  • pref.date_min.day = 1;
  • // mis en commentaire pour des tests, fonctionnel à 100%
  • // jusqu'au: 16 août 2003
  • //pref.date_max.year = 2003;
  • //pref.date_max.month = 8;
  • //pref.date_max.day = 16;
  • // par extension, nom de fichier, ce qu'il contient ou par taille
  • // exemple:
  • //pref.type = TYPE_BY_NAME;
  • //pref.filter = "nom d'un fichier avec ou sans extension";
  • // Or
  • //pref.type = TYPE_BY_EXT;
  • //pref.filter = "|.exe|.txt|.jpg|";
  • // Or
  • //pref.type = TYPE_BY_CONTAINT;
  • //pref.filter = "un mot ou une phrase ici";
  • // Or
  • //pref.type = TYPE_BY_SIZE;
  • //pref.size_min = 1024;
  • //pref.size_max = 5120; // optionnel, si non spécifié, seul les fichiers
  • // de 1024 bytes seulement seront trouvés
  • // même chose pour la recherche de type; TYPE_BY_DATE
  • pref.func_ptr.ptr = NEngine_OnFound; // lui donne l'adresse de la fonction à appeler si des fichiers sont trouvés
  • pref.use_event = true; // oui, on utilise l'event(fonction à appeler)
  • pref.break_on_error = false; // non, on continue même s'il y à une erreur
  • pref.path = "c:\\"; // répertoire de recherche
  • pref.subfolder = true; // oui, rechercher dans les sous-répertoires
  • find.SetPref(pref); // on lui donne nos préférences de recherche
  • dwStart = GetTickCount(); // démarre le compteur
  • retval = find.Start(); // lance la recherche
  • dwEnd = GetTickCount(); // stop le compteur
  • // affiche les statistiques de la recherche
  • cout << "\nValeur retourne: " << retval << "\nSignification: " << find.GetErrorDescription(retval) << "\n\n";
  • cout << "\nNombre de fichiers trouves: " << find.FilesCount() << "\n";
  • cout << "Nombre de repertoire parcourru: " << find.TotalFolders() << "\n";
  • cout << "Nombre de fichier verifie: " << find.TotalFiles() << "\n";
  • cout << "Temp d'execution: " << (long)(dwEnd-dwStart) << " milli sec\n\n";
  • return EXIT_SUCCESS;
  • }
  • // le nom de cette fonction ainsi que le nom des arguments peuvent être ce que vous voulez
  • // ex: void abc(const char* a, const char* b, const char* c, const unsigned long l, const char* d, FILETIME aa, FILETIME bb, FILETIME cc)
  • // appelé chaque fois qu'un fichier est trouvé sauf si dans vos préférences de recherche vous n'avez spécifié aucune fonction à appeler
  • void NEngine_OnFound(const char *LongFileName, const char *LongPathName, const unsigned long FileSize, const char *ShortFileName, FILETIME CreationTime, FILETIME LastAccessTime, FILETIME LastWriteTime)
  • {
  • SYSTEMTIME st;
  • LPFILETIME ft = &CreationTime;
  • FileTimeToSystemTime(ft, &st);
  • cout << "LongFileName: " << LongFileName << " - Date: year(" << st.wYear << "), month(" <<
  • st.wMonth << "), day(" << st.wDay << ")\n";
  • //cout << "LongFileName: " << LongFileName << " - Taille: " << FileSize << " bytes\n";
  • //cout << "LongFileName: " << LongFileName << "\n";
  • }
Exemple, le contenue du fichier main.cpp
**************************************************************

#include <iostream.h>
#include "nengine.h"

void NEngine_OnFound(const char *LongFileName, const char *LongPathName, const unsigned long FileSize, const char *ShortFileName, FILETIME CreationTime, FILETIME LastAccessTime, FILETIME LastWriteTime);

int main()
{

DWORD dwStart = 0;
DWORD dwEnd = 0;
NEnginePref pref;
NEngine find;
long retval = 0;

	/* Test, pour récupérer la taille d'un répertoire, fonctionnel à 100%
	unsigned long size = 0;
	pref.break_on_error = false;
	find.SetPref(pref);
	find.GetDirectorySize("e:\\", size, true);
	cout << "Directory size: " << size << " bytes\n";
	return 0;
	*/

	pref.type = TYPE_BY_DATE;
	// par date ...
	// à partir du: 1 août 2003
	pref.date_min.year = 2003;
	pref.date_min.month = 8;
	pref.date_min.day = 1;
	// mis en commentaire pour des tests, fonctionnel à 100%
	// jusqu'au: 16 août 2003
	//pref.date_max.year = 2003;
	//pref.date_max.month = 8;
	//pref.date_max.day = 16;

	// par extension, nom de fichier, ce qu'il contient ou par taille
	// exemple:
	//pref.type = TYPE_BY_NAME;
	//pref.filter = "nom d'un fichier avec ou sans extension";
	// Or
	//pref.type = TYPE_BY_EXT;
	//pref.filter = "|.exe|.txt|.jpg|";
	// Or
	//pref.type = TYPE_BY_CONTAINT;
	//pref.filter = "un mot ou une phrase ici";
	// Or
	//pref.type = TYPE_BY_SIZE;
	//pref.size_min = 1024;
	//pref.size_max = 5120;  // optionnel, si non spécifié, seul les fichiers
	                         // de 1024 bytes seulement seront trouvés
	                         // même chose pour la recherche de type; TYPE_BY_DATE

	pref.func_ptr.ptr = NEngine_OnFound;  // lui donne l'adresse de la fonction à appeler si des fichiers sont trouvés
	pref.use_event = true;  // oui, on utilise l'event(fonction à appeler)

	pref.break_on_error = false;  // non, on continue même s'il y à une erreur

	pref.path = "c:\\";  // répertoire de recherche
	pref.subfolder = true;  // oui, rechercher dans les sous-répertoires

	find.SetPref(pref);  // on lui donne nos préférences de recherche

	dwStart = GetTickCount();  // démarre le compteur
	retval = find.Start();  // lance la recherche
	dwEnd = GetTickCount();  // stop le compteur

	// affiche les statistiques de la recherche
	cout << "\nValeur retourne: " << retval << "\nSignification: " << find.GetErrorDescription(retval) << "\n\n";

	cout << "\nNombre de fichiers trouves: " << find.FilesCount() << "\n";
	cout << "Nombre de repertoire parcourru: " << find.TotalFolders() << "\n";
	cout << "Nombre de fichier verifie: " << find.TotalFiles() << "\n";
	cout << "Temp d'execution: " << (long)(dwEnd-dwStart) << " milli sec\n\n";

	return EXIT_SUCCESS;

}

// le nom de cette fonction ainsi que le nom des arguments peuvent être ce que vous voulez
// ex: void abc(const char* a, const char* b, const char* c, const unsigned long l, const char* d, FILETIME aa, FILETIME bb, FILETIME cc)
// appelé chaque fois qu'un fichier est trouvé sauf si dans vos préférences de recherche vous n'avez spécifié aucune fonction à appeler
void NEngine_OnFound(const char *LongFileName, const char *LongPathName, const unsigned long FileSize, const char *ShortFileName, FILETIME CreationTime, FILETIME LastAccessTime, FILETIME LastWriteTime)
{

SYSTEMTIME st;
LPFILETIME ft = &CreationTime;

	FileTimeToSystemTime(ft, &st);
	cout << "LongFileName: " << LongFileName << " - Date: year(" << st.wYear << "), month(" <<
		st.wMonth << "), day(" << st.wDay << ")\n";

	//cout << "LongFileName: " << LongFileName << " - Taille: " << FileSize << " bytes\n";
	//cout << "LongFileName: " << LongFileName << "\n";

}



 Conclusion

Testé et créé sous Visual C++ 6 et Windows 98SE/2000 Pro/2000 Serveur Seulement.


~(.::  NitRic  ::.)~

 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Historique

18 mai 2007 01:54:15 :
ajout des mots clés( Vous aussi, mettez vos sources à jour !!! Ajoutez les mots clés !!! )

 Sources du même auteur

TRONQUER UN FICHIER(C - WINDOWS)
COMMENT CALCULER LE TEMP D'EXÉCUTION DE CERTAINES FONCTIONS ...
Source avec Zip VSTACK ( EFFET DE PILE ) / TEMPLATE
Source avec Zip NLIST ( TEMPLATE )
Source avec Zip NSTRING (UPDATE) VERSION 1.5

 Sources de la même categorie

Source avec Zip Source avec une capture GENERE BMP par lajouad
Source avec Zip Source avec une capture GETIONNAIRE D'UNE BIBLIOTHÉQUE EN C par benzarabel
FONCTION D'ÉDITION DE FICHIER BIT À BIT [C-MULTIPLATEFORME] par lynxtyle
Source avec Zip Source avec une capture UN GESTIONNAIRE DU FICHIER par benzarabel
Source avec Zip COPIE DE FICHIERS PAR RESEAU LOCAL par cczerty

 Sources en rapport avec celle ci

GESTION DE FICHIER ET DOSSIER + AUTRES par shinji63
LISTER LES FICHIERS D'UN REPERTOIRE + FILTRES par yvesyves
Source avec Zip PROTEGER UN DOSSIER ET LES FICHIER A L INTERIEUR par f_l_a_s_h_b_a_c_k
Source avec une capture SCANNER DE DISQUES (RECURSIF) par yoyo269
Source avec Zip FINDFILE(UPDATE) par NitRic

Commentaires et avis

Commentaire de Xs le 29/10/2003 10:34:14

Je n'ai pas regardé NEngine.h mais rien qu'a voir le panel de fonctions.... je te dis bravo.
J'affectionne surtout la fonction par date par intervalle.

Commentaire de LordBob le 04/11/2003 21:03:20

ouais c'est vrai que c'est bien...

Commentaire de azimz le 06/05/2005 14:01:55

un grand bravi excellemment bien programmé

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

Moteur de recherche en C [ par christophebalet198406 ] Bonjour &#224; tous, je souhaite r&#233;aliser un moteru de recherche en C. La recherche s'effecture&nbsp;&#224; partir d'une liste de fichier &#224; recherche un dossier par date de creation [ par mickaaaael ] Bonjour,J'aimerai trouver un logiciel qui me permettrai de récupérer le dernier fichier crée dans un dossier X pour le mettre dans un dossier Y et qu' Installation et utilisation de Libxml2 sous windows [ par boualiasma ] Salut,Je suis entrain de programmer en C avec Visual studio 2008 sous Windows.Je voudrais parser un fichier XML dans mon programme C. J'ai trouvé libx ecriture d'un txt dans le même dossier [ par MiharbiDoNo ] j'essai d'ecrire un fichier txt a l'aide de [code=cpp]ofstream myfile; myfile.open ("exemple.txt");[/code] le probleme c'est l'emplacement du fichier Copie de fichiers et dossiers [ par abdelwaheb_ammar ] bonjour bonjour je veux faire un projet de gestion de dossier et dossier sur C++mais je ne trouve pas la commandes qui me permet de copier un dossier Comment trouver la fin d'un fichier avec fonctions windows [ par dante20007 ] Bonjour, je voudrais détecter la fin de mon fichier en termes de caractères.J'ai essayé avec la fonction (feof) mais elle ne me donne pas mon dernier recherche dans un fichier [ par brainniac1 ] Salut, je voudrais savoir comment chercher un mot dans un fichier?Merci, d'avance !!! Outil de recherche [ par _michel ] J'ai remarqué quelques insuffisances du moteur de recherche de code source : pour rechercher une source que l'on a postée, par exemple, il y a de quoi Fichier qui affiche dans la console tout les fichiers et dossier du lecteur C [ par kiitos ] Comment faire un fichier qui affiche dans la console tout les fichiers et dossier du lecteur C ? EOF avec les API Windows [ par faucheuse ] Bien le bonjour ami(e)s programmeurs et programmeuzes,Je débute avec les API Windows et j'ai une classe à faire pour le manipulation de fichier (Creer


Nos sponsors


Sondage...

CalendriCode

Février 2012
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
272829    

Consulter la suite du CalendriCode

Photothèque

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 1,373 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales