Recupero e modifica degli attributi di file

Un'applicazione può recuperare gli attributi del file usando la funzione GetFileAttributes o GetFileAttributesEx. Le funzioni CreateFile e SetFileAttributes possono impostare molti degli attributi. Tuttavia, le applicazioni non possono impostare tutti gli attributi.

L'esempio di codice in questo argomento usa la funzione CopyFile per copiare tutti i file di testo (.txt) nella directory corrente in una nuova directory di file di sola lettura. I file nella nuova directory vengono modificati solo in lettura, se necessario.

L'applicazione crea la directory specificata come parametro usando la funzione CreateDirectory . La directory non deve esistere già.

L'applicazione cerca la directory corrente per tutti i file di testo usando le funzioni FindFirstFile e FindNextFile . Ogni file di testo viene copiato nella directory \TextRO. Dopo la copia di un file, la funzione GetFileAttributes determina se un file è di sola lettura. Se il file non viene letto solo, l'applicazione modifica le directory in \TextRO e converte il file copiato in sola lettura usando la funzione SetFileAttributes .

Dopo la copia di tutti i file di testo nella directory corrente, l'applicazione chiude l'handle di ricerca usando la funzione FindClose .

#include <windows.h>
#include <tchar.h>
#include <stdio.h>
#include <strsafe.h>

void _tmain(int argc, TCHAR* argv[])
{
   WIN32_FIND_DATA FileData;
   HANDLE          hSearch;
   DWORD           dwAttrs;
   TCHAR           szNewPath[MAX_PATH];   
 
   BOOL            fFinished = FALSE; 

   if(argc != 2)
   {
      _tprintf(TEXT("Usage: %s <dir>\n"), argv[0]);
      return;
   }
 
// Create a new directory. 
 
   if (!CreateDirectory(argv[1], NULL)) 
   { 
      printf("CreateDirectory failed (%d)\n", GetLastError()); 
      return;
   } 
 
// Start searching for text files in the current directory. 
 
   hSearch = FindFirstFile(TEXT("*.txt"), &FileData); 
   if (hSearch == INVALID_HANDLE_VALUE) 
   { 
      printf("No text files found.\n"); 
      return;
   } 
 
// Copy each .TXT file to the new directory 
// and change it to read only, if not already. 
 
   while (!fFinished) 
   { 
      StringCchPrintf(szNewPath, sizeof(szNewPath)/sizeof(szNewPath[0]), TEXT("%s\\%s"), argv[1], FileData.cFileName);

      if (CopyFile(FileData.cFileName, szNewPath, FALSE))
      { 
         dwAttrs = GetFileAttributes(FileData.cFileName); 
         if (dwAttrs==INVALID_FILE_ATTRIBUTES) return; 

         if (!(dwAttrs & FILE_ATTRIBUTE_READONLY)) 
         { 
            SetFileAttributes(szNewPath, 
                dwAttrs | FILE_ATTRIBUTE_READONLY); 
         } 
      } 
      else 
      { 
         printf("Could not copy file.\n"); 
         return;
      } 
 
      if (!FindNextFile(hSearch, &FileData)) 
      {
         if (GetLastError() == ERROR_NO_MORE_FILES) 
         { 
            _tprintf(TEXT("Copied *.txt to %s\n"), argv[1]); 
            fFinished = TRUE; 
         } 
         else 
         { 
            printf("Could not find next file.\n"); 
            return;
         } 
      }
   } 
 
// Close the search handle. 
 
   FindClose(hSearch);
}

Costanti dell'attributo file

Nomi di file, percorsi e spazi dei nomi