Section courante

A propos

Section administrative du site

Entrée et sortie de fichier texte

La communication entre les personnes et les systèmes informatiques utilise un types de fichiers. Les deux apprennent à comprendre grâce à ce que l'on appelle la reconnaissance des modèles. Malheureusement, les modèles les plus facilement reconnus par les gens (principalement ceux de l'image et du son) sont très différents de ceux acceptables pour les systèmes informatiques (impulsions électriques). En fait, les frais de transmission physique des données - impliquant une traduction de modèles lisibles par les gens en ceux lisibles par les systèmes informatiques et vice versa - peuvent être aussi coûteux que le traitement des données lui-même. Par conséquent, de nombreuses recherches sont consacrées à la minimisation des coûts en automatisant davantage le processus de traduction. Cette tâche de communication est appelée gestion des entrées et sorties. Les gens peuvent transmettre des informations aux systèmes informatiques via des périphériques d'entrée et des supports (par exemple, des claviers, des disquettes, des disques durs, des dispositifs de pointage, des cartouches de bande, des disques optiques, des bandes magnétiques, des terminaux) et recevoir des résultats via des périphériques et supports de sortie (par exemple, imprimantes, bandes magnétiques, disquettes, disques dur, cartouches de bande, disques optiques, traceurs, haut-parleurs et écrans vidéo). Ce qui est commun à la plupart d'entre eux - et défini par chaque installation informatique individuelle - est un ensemble de caractères lisibles. C'est sur cette ensemble de caractères que Pascal définit le type standard Text.

Il est important de se rappeler que chacun de ces périphériques d'entrée-sortie applique certaines conventions quant à la signification de caractères et de modèles (chaînes de caractères) de caractères spécifiques. Par exemple, la plupart des imprimantes appliquent une longueur de ligne maximale. De plus, de nombreuses imprimantes de ligne plus anciennes interprètent le premier caractère de chaque ligne comme un caractère de «contrôle du chariot», n'étant pas imprimé mais peut provoquer une action telle qu'une éjection de page ou une surimpression. Lorsqu'un fichier texte est utilisé pour représenter un périphérique particulier, le programme doit obéir aux conventions d'utilisation de ce périphérique.

Les fichiers texte sont accessibles via les procédures de fichier prédéclarées Get et Put. Cela peut, bien sûr, être assez fastidieux car ces procédures sont définies pour la manipulation d'un seul caractère. Pour illustrer, supposons que nous ayons un nombre naturel entreposé dans une variable x et souhaitons l'écrire sur la sortie du fichier. Notez que le modèle de caractères dénotant la représentation décimale de la valeur sera assez différent de celui dénotant la valeur écrite sous forme de chiffre romain. Mais comme nous nous intéressons généralement à la notation décimale, il semble judicieux de proposer des procédures de transformation standard intégrées convertissant les nombres abstraits (quelle que soit la représentation interne à l'ordinateur) en séquences de chiffres décimaux et vice versa. Les deux procédures prédéclarées Read et Write sont ainsi étendues de plusieurs manières pour faciliter l'analyse et la formation des fichiers texte.

L'entrée et la sortie des fichiers standard

Les fichiers texte standard Input et Output représentent généralement les supports d'entrée/sortie standard d'un système informatique (tels que le clavier et l'affichage vidéo). Par conséquent, ils sont la principale ligne de communication entre le système informatique et son utilisateur humain. Étant donné que ces deux fichiers sont très fréquemment utilisés, ils sont considérés comme des valeurs par défaut dans les opérations de fichier texte lorsque le fichier texte F n'est pas explicitement indiqué. C'est le cas pour ceux-ci :

Utilisation Réellement appliqué
Write(Ch) = Write(Output,Ch)
Read(Ch) = Read(Input,Ch)
WriteLn = WriteLn(Output)
Readln = ReadLn(Input)
Eof = Eof(Input)
Eoln = Eoln(Input)
Page = Page(Output)

Si l'une de ces procédures et fonctions est utilisée sans indication d'un paramètre de fichier, la convention par défaut spécifie que le fichier standard Input ou Output est supposé; dans ce cas, il doit être placé dans la liste des paramètres de l'entête du programme. Remarque : L'effet de l'application de la procédure prédéclarée Reset ou Rewrite à Input ou Output est défini par la mise en oeuvre. Par conséquent, la lecture et l'écriture d'un fichier texte peuvent être exprimées comme suit (supposons Var Ch:Char; B1,B2:Boolean; et P, Q et R procédures définies par l'utilisateur). Écriture de caractères sur le fichier de sortie (Output) :

  1. Var
  2.  B1,B2:Boolean;
  3.  Ch:Char;
  4.  
  5. Procedure P(C:Char);Begin
  6.  { ... }
  7. End;
  8.  
  9. BEGIN
  10.  B1:=True;
  11.  B2:=True;
  12.  Repeat
  13.   Repeat 
  14.    P(Ch); 
  15.    Write(Ch);
  16.   Until B1;
  17.   WriteLn;
  18.  Until B2;
  19. END.

Lecture des caractères à partir du fichier d'entrée (Input) :

  1. Var
  2.  Ch:Char;
  3.  
  4. Procedure P;Begin
  5.  { ... }
  6. End;
  7.  
  8. Procedure Q(C:Char);Begin
  9.  { ... }
  10. End;
  11.  
  12. Procedure R;Begin
  13.  { ... }
  14. End;
  15.  
  16. BEGIN
  17.  While Not Eof do Begin 
  18.   {Processus en ligne} P;
  19.   While Not Eoln do Begin 
  20.    Read(Ch); 
  21.    Q(Ch);
  22.   End;
  23.   R; 
  24.   ReadLn;
  25.  End;
  26. END.


Dernière mise à jour : Dimanche, le 11 novembre 2020