begin process at 2012 02 14 15:07:16
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Fichier / Disque

 > ATTRIB4ALLB3 - CHANGER LES ATTRIBUTS DE TOUS FICHIERS D'1 DOSSIER EN ENTIER (AVEC SOUS-DOSSIERS)

ATTRIB4ALLB3 - CHANGER LES ATTRIBUTS DE TOUS FICHIERS D'1 DOSSIER EN ENTIER (AVEC SOUS-DOSSIERS)


 Information sur la source

Note :
8,5 / 10 - par 4 personnes
8,50 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :Fichier / Disque Niveau :Débutant Date de création :29/08/2002 Date de mise à jour :29/08/2002 23:07:10 Vu / téléchargé :4 972 / 373

Auteur : BobBigBoss

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

 Description

Cliquez pour voir la capture en taille normale
Voici un code qui permet de changer les attributs des fichiers de manière récursive.
Il s'applique aux fichiers sélectionnés d'un dossier, ou à tous le dossier seul, ou encore à tous le dossier en entier, incluant tous ses sous-dossiers (c'est ce qu'on appelle la récursivité). J'ai écrit ce code car j'en avais marre de toujours trouver du code qui ne s'applique qu'à un certain nombre de niveau de sous-dossiers. N'oubliez pas de voter !

Source

  • 'Voici un petit cours sur le FileSystemObject et les attributs de fichiers.
  • '* Avant tout, dans le projet il faut faire référence à la classe FileSystemObject :
  • ' Menu " Projet " -> " Références " -> Cocher " Microsoft Scripting Runtime " -> Valider.
  • ' Cette classe va nous permettre de manipuler les lecteurs, dossiers et fichiers.
  • '* Ensuite, il faut créer un objet FileSystemObject :
  • Dim fso As New FileSystemObject
  • ' Cette méthode de déclaration est la plus simple, et n'est possible que si la référence a été faite.
  • ' Il existe d'autres méthodes où la référence n'est pas nécéssaire.
  • '* Puis il faut créer des variables objets lecteur, dossier et fichier (selon nos besoins) :
  • Dim lecteur As Drive, dossier As Folder, fichier As File
  • ' Ces variables vont nous permettre de manipuler ces objets de manière directe.
  • '* Pour affecter un objet à sa variable correspondante, il suffit de faire :
  • lecteur = fso.GetDrive("D:")
  • dossier = fso.GetFoler("E:\Mes documents")
  • fichier = fso.GetFile("C:\Autoexec.bat")
  • ' Désormais, à chaque fois que l'on effectuera une action sur la variable objet "dossier",
  • ' ce sera en réalité sur le dossier "Mes documents" du lecteur "E" que cette action sera effectuée.
  • '* Pour agir sur chacun de ces objets, il faut modifier leur propriétés. Ex :
  • MsgBox fichier.Path '==> ceci affiche le chemin du répertoire du fichier
  • MsgBox fichier.Attributes '==> ceci affiche la valeur des attributs du fichier (sous forme d'un nombre entier)
  • fichier.Attributes = vbReadOnly '==> ceci efface tous les attributs du fichier puis lui donne l'attribut "Lecture seule"
  • '* NB : regarder les attributs d'un fichier, c'est ce que l'on fait quand on clique-droit sur le fichier
  • ' et que l'on sélectionne "Propriétés". Tout en bas de la fenêtre, il y a 3 cases à cocher visibles
  • ' (Lecture seule, Caché et Archive) et une case désactivée (Système)
  • '* En ce qui concerne les attributs de fichier, voici leur valeur :
  • vbNormal = 0 '==> aucun attribut
  • vbReadOnly = 1 '==> fichier en "Lecture seule"
  • vbHidden = 2 '==> fichier "Caché"
  • vbSystem = 4 '==> fichier "Système"
  • vbArchive = 32 '==> fichier "Archive"
  • '* On peut également combiner plusieurs attributs pour le fichier. Ex :
  • fichier.Attributes = vbReadOnly + vbHidden '==> Le fichier possède maintenant les attributs "Lecture seule" et "Caché"
  • 'ACTION sur tous les fichiers d'un dossier incluant ses sous-dossier (pour un accès non binaire) :
  • 'Faire une référence à la classe FileSystemObject dans le projet : Menu " Projet " -> " Références " -> Cocher " Microsoft Scripting Runtime " -> Valider
  • Option Explicit
  • Dim fso As New FileSystemObject, dossier As Folder, sousDossier As Folder, fichier As File
  • 'dans une procédure :
  • 'récupérer le dossier concerné comme par exemple :
  • Set dossier = fso.GetFolder("C:\Mes documents")
  • '...
  • 'agir d'abord sur les fichiers du dossier courant
  • For Each fichier In dossier.Files
  • 'Action à effectuer comme par exemple "fichier.Attributes = vbNormal"
  • '...
  • Next
  • 'maintenant on passe aux sous-dossiers
  • For Each sousDossier In dossier.SubFolders
  • Call Pour_Les_Sous_Dossiers(sousDossier)
  • Next
  • '...
  • End Sub
  • '--------------------------------------------------------------------------------------------------------------------------
  • Private Sub Pour_Les_Sous_Dossiers(ByVal dossier As Folder)
  • 'agir d'abord sur les fichiers du sous-dossier courant
  • For Each fichier In dossier.Files
  • 'Action à effectuer comme par exemple "fichier.Attributes = vbNormal"
  • '...
  • Next
  • 'maintenant on passe aux sous-dossiers du sous-dossier courant
  • For Each sousDossier In dossier.SubFolders
  • Call Pour_Les_Sous_Dossiers(sousDossier)
  • Next
  • End Sub
'Voici un petit cours sur le FileSystemObject et les attributs de fichiers.

'* Avant tout, dans le projet il faut faire référence à la classe FileSystemObject :
'    Menu " Projet " -> " Références " -> Cocher " Microsoft Scripting Runtime " -> Valider.
'  Cette classe va nous permettre de manipuler les lecteurs, dossiers et fichiers.
'* Ensuite, il faut créer un objet FileSystemObject :
    Dim fso As New FileSystemObject
'  Cette méthode de déclaration est la plus simple, et n'est possible que si la référence a été faite.
'  Il existe d'autres méthodes où la référence n'est pas nécéssaire.

'* Puis il faut créer des variables objets lecteur, dossier et fichier (selon nos besoins) :
    Dim lecteur As Drive, dossier As Folder, fichier As File
'  Ces variables vont nous permettre de manipuler ces objets de manière directe.

'* Pour affecter un objet à sa variable correspondante, il suffit de faire :
    lecteur = fso.GetDrive("D:")
    dossier = fso.GetFoler("E:\Mes documents")
    fichier = fso.GetFile("C:\Autoexec.bat")
'  Désormais, à chaque fois que l'on effectuera une action sur la variable objet "dossier",
'  ce sera en réalité sur le dossier "Mes documents" du lecteur "E" que cette action sera effectuée.

'* Pour agir sur chacun de ces objets, il faut modifier leur propriétés. Ex :
    MsgBox fichier.Path			'==> ceci affiche le chemin du répertoire du fichier
    MsgBox fichier.Attributes		'==> ceci affiche la valeur des attributs du fichier (sous forme d'un nombre entier)
    fichier.Attributes = vbReadOnly	'==> ceci efface tous les attributs du fichier puis lui donne l'attribut "Lecture seule"

'* NB : regarder les attributs d'un fichier, c'est ce que l'on fait quand on clique-droit sur le fichier
'  et que l'on sélectionne "Propriétés". Tout en bas de la fenêtre, il y a 3 cases à cocher visibles
'  (Lecture seule, Caché et Archive) et une case désactivée (Système)

'* En ce qui concerne les attributs de fichier, voici leur valeur :
    vbNormal	= 0	'==> aucun attribut
    vbReadOnly	= 1	'==> fichier en "Lecture seule"
    vbHidden	= 2	'==> fichier "Caché"
    vbSystem	= 4	'==> fichier "Système"
    vbArchive	= 32	'==> fichier "Archive"

'* On peut également combiner plusieurs attributs pour le fichier. Ex :
    fichier.Attributes = vbReadOnly + vbHidden		'==> Le fichier possède maintenant les attributs "Lecture seule" et "Caché"



'ACTION sur tous les fichiers d'un dossier incluant ses sous-dossier (pour un accès non binaire) :

'Faire une référence à la classe FileSystemObject dans le projet : Menu " Projet " -> " Références " -> Cocher " Microsoft Scripting Runtime " -> Valider
Option Explicit
Dim fso As New FileSystemObject, dossier As Folder, sousDossier As Folder, fichier As File

'dans une procédure :
'récupérer le dossier concerné comme par exemple :
Set dossier = fso.GetFolder("C:\Mes documents")
'...
'agir d'abord sur les fichiers du dossier courant
For Each fichier In dossier.Files
	'Action à effectuer comme par exemple "fichier.Attributes = vbNormal"
'...
Next
'maintenant on passe aux sous-dossiers
For Each sousDossier In dossier.SubFolders
	Call Pour_Les_Sous_Dossiers(sousDossier)
Next
'...
End Sub
'--------------------------------------------------------------------------------------------------------------------------
Private Sub Pour_Les_Sous_Dossiers(ByVal dossier As Folder)
'agir d'abord sur les fichiers du sous-dossier courant
For Each fichier In dossier.Files
	'Action à effectuer comme par exemple "fichier.Attributes = vbNormal"
'...
Next
'maintenant on passe aux sous-dossiers du sous-dossier courant
For Each sousDossier In dossier.SubFolders
	Call Pour_Les_Sous_Dossiers(sousDossier)
Next
End Sub

 Conclusion

La prochaine version sera pour bientôt, et plus complète.

 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


 Sources du même auteur

Source avec Zip Source avec une capture AVI&MPXB3 - LECTEUR DIVX ET VCD-SVCD UTILISANT LE CONTRÔLE M...

 Sources de la même categorie

Source avec Zip Source .NET (Dotnet) MODIFIER LES EXTENSION DES FICHIERS par okosa
ROUTINE DIR RÉCURSIVE POUR OBTENIR LA LISTE DE TOUS LES FICH... par kerisolde
Source avec Zip Source avec une capture FILE,SECURITY,FICHIER par okosa
Source avec Zip Source avec une capture Source .NET (Dotnet) PATCHEUR DE FICHIER par tototh
Source avec Zip Source avec une capture LECTURE DES INFORMATIONS DES DISQUES COMPOSANT UN ENSEMBLE R... par jack

Commentaires et avis

Commentaire de BobBigBoss le 31/08/2002 01:50:59

J'ai oublié de préciser, dans ce projet j'utilise, comme vous avez pus le remarquer, un FSO et une technique de programmation qu'on appelle la récursivité

Commentaire de ebe_tic le 23/02/2005 16:22:51

Pas mal ! mais la date ? ou plutôt les dates (création, modification) comment on fait pour les modifier ?
En tout cas c'est l'occasion pour moi de bosser sur FSO... je ne m'en sers jamais.

Commentaire de DarkCid le 24/03/2005 09:11:40

Yaoh !

Sympa comme source mais il y a une petite erreur :
kan tu écris
lecteur = fso.GetDrive("D:")
    dossier = fso.GetFoler("E:\Mes documents")
    fichier = fso.GetFile("C:\Autoexec.bat")

il faut mettre set devant (set lecteur = blabla...)

voilà, mais sinon sa marche impec

 Ajouter un commentaire




Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Février 2012
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
272829    

Consulter la suite du CalendriCode

 
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 : 2,262 sec (3)

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