C ++: système de fichiers boost pour retourner une liste de fichiers plus qu'un temps spécifique

StackOverflow https://stackoverflow.com/questions/4279164

  •  28-09-2019
  •  | 
  •  

Question

J'utilise la bibliothèque Boost::FileSystem en C ++ fonctionnant sous plate-forme Linux et j'ai une question suivante:

Je voudrais avoir une liste des fichiers qui sont modifiés plus qu'un temps de date donnée. Je ne sais pas si l'offre boost::FileSystem une telle méthode que:

vector<string> listFiles = boost::FileSystem::getFiles("\directory", "01/01/2010 12:00:00");

Si oui, pouvez-vous s'il vous plaît fournir un exemple de code?

Était-ce utile?

La solution

Boost :: système de fichiers n'offre pas une fonction exactement comme ça. Mais vous pouvez utiliser ceci:

http://www.boost.org/doc /libs/1_45_0/libs/filesystem/v3/doc/reference.html#last_write_time

comme base pour écrire votre propre. Voici quelques exemples de code utilisant last_write_time:

#include <boost/filesystem/operations.hpp>
#include <ctime>
#include <iostream>

int main( int argc , char *argv[ ] ) {
   if ( argc != 2 ) {
      std::cerr << "Error! Syntax: moditime <filename>!\n" ;
      return 1 ;
   }
   boost::filesystem::path p( argv[ 1 ] ) ;
   if ( boost::filesystem::exists( p ) ) {
      std::time_t t = boost::filesystem::last_write_time( p ) ;
      std::cout << "On " << std::ctime( &t ) << " the file " << argv[ 1 ] 
     << " was modified the last time!\n" ;
      std::cout << "Setting the modification time to now:\n" ;
      std::time_t n = std::time( 0 ) ;
      boost::filesystem::last_write_time( p , n ) ; 
      t = boost::filesystem::last_write_time( p ) ;
      std::cout << "Now the modification time is " << std::ctime( &t ) << std::endl ;
      return 0 ;
   } else {
      std::cout << "Could not find file " << argv[ 1 ] << '\n' ;
      return 2 ;
   }
}

Autres conseils

Vous pouvez utiliser un std :: map (last_write_time, fileName) pour stocker le fichier de la dernière fois modifié et le chemin du fichier absolu et le faire en un ordre traversal pour trier les données.

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top