I. Les fichiers à accès séquentiel ♪▲
Dans certains tutoriels que je diffuse sur Internet, je fais référence à la création de fichiers afin de stocker des données en mémoire inhérente aux applications développées.
Aussi, je vous propose d'étudier les bases de la gestion des fichiers pouvant vous servir dans la plupart des applications que vous aurez à développer.
Visual Basic possède les fonctions fondamentales de gestion de fichiers séquentiels, à accès direct et binaire.
Quel que soit le mode de gestion adopté, nous ouvrirons les fichiers à l'aide de l'instruction « Open » et nous les fermerons avec l'instruction « Close ».
Recherchons dans Visual Basic les caractéristiques de l'instruction « Open »
Description : Ouvre un fichier
Syntaxe : Open fichier$ [For Mode ] [ Access accès ] [ Look ] As [#] identificateur fichier% [ Len=longueur%]. (Cette chaîne de caractère doit être écrite sur la même ligne.)
fichier$ : Chaîne de caractères dont la valeur décrit le nom du fichier à ouvrir.
mode : Vous pouvez entrer ici une chaîne de caractères dont la valeur définit le mode de transfert des données et doit contenir l'une des expressions suivantes :
- Random : Mode d'accès direct
- Random : Mode d'accès direct
- Binary : Mode binaire. Tout octet est lu ou écrit par « Get » et « Put »
- Input : Entrée séquentielle.
- Output : Sortie séquentielle.
- Append : Sortie séquentielle ajoutée à la fin d'un fichier existant.
Le mot clé Access est réservé aux versions du DOS supérieures ou égales à 3.1
En paramètre, on peut passer une chaîne de caractères contenant l'une des expressions suivantes.(Attribut)
- Read : Lecture seulement
- Write : Écriture seulement
- Read Write : Lecture et écriture. Réservé aux fichiers ouverts en mode Binary ou Append
- Lock : Le fichier peut, avec l'un des mots-clés suivants, être doté de certains droits d'accès autres que Lock :
- Shared : Tout programme peut accéder au fichier et lire ou écrire des données.
- Lock Read : Aucun autre programme ne peut lire des données dans ce fichier.
- Lock Write : Aucun autre programme ne peut écrire de données dans ce fichier.
Identificateur fichier : Expression numérique comprise entre 1 et 255 donnant le numéro de fichier.
Longueur : Expression numérique comprise entre 1 et 32767. Le fichier est ouvert en accès libre avec des enregistrements de longueur « longueur ».
Open "C:\WINDOWS\SYSTEM\DATA.DAT" For Input As #2 Lock Read
En principe nous écrirons notre fichier dans le répertoire de Windows ou de System, mais pour le cas où vous souhaiteriez le créer dans un répertoire nous allons étudier de prime abord la création du répertoire devant accueillir notre fichier
|
|
L'application « CREREP » |
Private Sub Command2_Click()
'Contrôler si répertoire existe?
Dim MyPath As String 'Définition des variables
Dim MyName As String
Dim RepertName As String
'
RepertName$ = Text1.Text
MyPath = "C:\windows\" & RepertName$ 'On initialise la variable
If Text1.Text = "" Then
Title$ = "Création d'un répertoire"
msg = "Veuillez saisir le nom du répertoire à créer!"
MsgBox msg, 64, Title$
Text1.SetFocus
Else
'Instructions
End If
'Si l'utilisateur n'a pas saisi un nom... alors sortie du programme
If Text1.Text = "" Then Exit Sub
'Puisqu'il a saisi un nom, nous traitons sa demande!
If (MyName = Dir(MyPath, vbDirectory)) = vbEmpty Then
'On teste l'existence du répertoire
MsgBox "Le répertoire " & Chr(34) & MyPath & Chr(34) & " existe bien!"
'Si le répertoire saisi existe... alors sortons....
Exit Sub
Else
MsgBox "Le répertoire " & Chr(34) & MyPath & Chr(34) & " n 'existe pas!", vbExclamation
'Alors...créons le répertoire
RepertName$ = Text1.Text
MkDir "c:\windows\" & RepertName$ 'Indiquez le chemin ou doit être stocké le répertoire
End If
'Ouverture d'une fenêtre de dialogue
MsgBox "Le répertoire " & RepertName$ & " vient d'être créé!"
End SubPour pouvoir écrire dans un fichier, nous devons d'abord le créer, quelles sont les fonctions que nous offre VB pour nous permettre de créer un fichier sous Windows ?
ÉCRIRE DANS UN FICHIER
Tous les fichiers devant comporter un numéro, nous utiliserons la fonction « FreeFile » qui retourne le premier numéro de fichier libre.
Quelles sont les informations que nous donne VB sur cette Fonction :
Description : Retourne l'identificateur de fichier suivant et disponible.
Remarque : Cette fonction est particulièrement utile quand vous désirez ouvrir un fichier sans savoir avec certitude si l'identificateur de fichier n'est pas déjà occupé.
Nous allons le conserver dans la variable NumFich(Numéro de fichier), nous écrivons
NumFich = FreeFile
Création du fichier « Protect.org » (vous pouvez saisir le nom de votre choix)
Sub CreatSerialNumberCode()
Dim UserCode As String
Dim SerialCode As String
Dim PasswordNumberCode As String
Dim Valeur As String
Dim UserName As String
Dim msg As String
Dim MonFichier As String
'
'Rechercher si le fichier existe?
NumFich = FreeFile
MonFichier$ = "c:\windows\protect.org"
If Dir(MonFichier$, vbNormal Or vbReadOnly Or vbHidden Or vbArchive) = "" Then
'Le fichier n'existe pas, alors...le créer!
Open "c:\windows\protect.org" For Output As #NumFich
'=============== [Affichage]====================
'Ecriture des valeurs dans la clé [Affichage]
Print #NumFich, "[Affichage]"
Valeur$ = "0" 'Récupérer la valeur dans le champ de saisie approprié - Ex Protect.lblAffichage.Caption
'Afficher la valeur récupérée
Print #NumFich, "Device="; Valeur$
'=============== [UserName ]====================
'Écriture des valeurs dans la clé [UserName]= Nom de l'utilisateur
Print #NumFich, "[UserName]"
UserName$ = "0" 'Récupérer la valeur dans le champ de saisie approprié - Ex Protect.lblUsername.Caption
'Afficher la valeur récupérée
Print #NumFich, "Device="; UserName$
'================ [UserCode ]====================
'Écriture des valeurs dans la clé [UserCode] = Nom de l'ordinateur
Print #NumFich, "[UserCode]"
UserCode$ = "0" 'Récupérer la valeur dans le champ de saisie approprié - Ex Protect.lblUserCode.Caption
'Afficher la valeur récupérée
Print #NumFich, "Device="; UserCode$
'================ [NumberSerie ]==================
'Ecriture des valeurs dans la clé [Serial Code]Code de contrôle
SerialCode$ = "0" 'Récupérer la valeur dans le champ de saisie approprié - Ex Protect.lblSerialCode.Caption
Print #NumFich, "[SerialCode]"
'Afficher la valeur récupérée
Print #NumFich, "Device="; SerialCode$
'================== [Password ]=================
'Écriture des valeurs dans la clé [Password]
Print #NumFich, "[Password]"
PasswordNumberCode$ = "0" 'Récupérer la valeur dans le champ de saisie approprié - Ex Protect.lblPasswordNumberCode.Caption
'Afficher la valeur récupérée
Print #NumFich, "Device="; PasswordNumberCode$
'Ferme le fichier
Close #1
Else
'Le fichier existe, alors...pas de commentaires, sortie...
End If
End SubDans cet exemple si vous ne remplacez pas la valeur « 0 » par le contenu du champ de saisie de l'exemple cité, vous afficherez « 0 »(Zéro)
|
|
L'application CREATFILE |
NomFile$ = ctlTexte1.Text
NumFich = FreeFile
Open NomFile$ + ".org" For Output As #NumFichL'extension est fantaisiste, libre choix à vous d'utiliser celle qui vous conviendra.
Télécharger l'exemple ci-contre ici !
Vous savez dorénavant créer un répertoire, créer un fichier et saisir les données que vous souhaitez mettre en mémoire, il ne nous reste plus qu'à réaliser l'application qui va nous permettre de lire ce fichier.
Vous ajoutez une zone de liste et vous lisez dans celle-ci les données enregistrées afin de les traiter dans votre application.
Prochain tutoriel▲
Les applications réalisées sans interface utilisateur



