M3 - Programació estructurada / Continguts UF3: Fitxers de text

De wikiserver
La revisió el 10:22, 8 feb 2018 per Rsort (Discussió | contribucions) (Creació d’un arxiu de text d’accés seqüencial)
Dreceres ràpides: navegació, cerca

Arxius de text seqüencials

Creació d’un arxiu de text d’accés seqüencial

El programa següent crea un arxiu simple d'accés seqüencial, que podria utilitzar-se en un sistema de comptes per cobrar per ajudar a administrar els diners que deuen a una companyia els clients a crèdit. Per cada client, el programa obté un número de compte, el nom del client i el seu saldo (és a dir, la suma que el client encara deu a la companyia pels béns i serveis rebuts). Les dades obtingudes per a cada client constitueixen un “registre” per a aquest client. El número de compte s'utilitza com la clau de registre en aquesta aplicació; l'arxiu es crearà i mantindrà en ordre basat en el número de compte. El programa suposa que l'usuari introdueix els registres en ordre de número de compte.

La classe Compte guarda la informació de registre del client:

   public class Compte {
     int compte;
     String nom;
     String cognom;
     double saldo;
   }

Ara examinarem la classe CrearArxiuText (codi següent). Es declara la variable Formatter anomenada sortida. Un objecte Formatter pot enviar dades a diverses ubicacions, com la pantalla o a un arxiu, com ho fem aquí. L'objecte Formatter s'instancia en el mètode obrirArxiu. Per a crear-lo s'utilitza un objecte String que conté el nom de l'arxiu, incloent la seva ruta. Si no s’especifica una ruta, com es dóna aquí el cas, s’assumeix que els arxius estan en el directori des del qual es va executar el programa. Si l'arxiu no existeix, es crearà. Si s'obre un arxiu existent, el seu contingut es sobrescriu. En aquest punt, l'arxiu s'obre per a escriptura i l'objecte Formatter resultant es pot utilitzar per escriure dades en l'arxiu.

El mètode agregarRegistres demana a l'usuari que introdueixi els diversos camps per a cada registre. Si el número de compte és positiu s'escriu a clients.txt mitjançant el mètode format. Aquest mètode pot efectuar un format idèntic al del mètode System.out.printf, que es va utilitzar en molts dels exemples de temes anteriors. Aquest mètode envia una cadena amb format a la destinació de sortida de l'objecte Formatter, en aquest cas l'arxiu clients.txt. La cadena de format "%d %s %s %.2f" indica que el registre actual s'emmagatzemarà com un enter (el número de compte) seguit d'una cadena (el primer nom), una altra cadena (el cognom) i un valor real (el saldo). Cada peça d'informació se separa de la següent, mitjançant un espai, i el valor tipus double (el saldo) s'imprimeix amb dos dígits a la dreta del punt decimal. Les dades en l'arxiu de text es poden veure amb un editor, o posteriorment mitjançant un programa dissenyat per llegir l'arxiu.

En el mètode tancarArxiu es tanca l'objecte Formatter i l'arxiu de sortida subjacent, mitjançant una crida al mètode close. Si el mètode close no es crida en forma explícita, el sistema operatiu normalment tanca l'arxiu quan el programa acaba d'executar-se.

   public class CrearArxiuText {

     private Formatter sortida;

     public void obrirArxiu() throws FileNotFoundException {
     
       sortida = new Formatter("clients.txt");
     }

     public void agregarRegistres() {

       Compte registre;
       String cognom, nom;
       double saldo;
       int compte = 1;
       Scanner entrada = new Scanner(System.in);
       System.out.println("Per finalitzar l'entrada, escriu un número de compte negatiu");
       System.out.println("Escriu el numero de compte (> 0), nom, cognom i saldo.");
       while (compte > 0 && entrada.hasNext()) {
         compte = entrada.nextInt();
         if (compte > 0) {
           registre = new Compte();
           registre.compte = compte;
           registre.nom = entrada.next();
           registre.cognom = entrada.next();
           registre.saldo = entrada.nextDouble();
           sortida.format("%d %s %s %.2f\n", registre.compte, registre.nom, registre.cognom, registre.saldo);
           System.out.println("Escriu el numero de compte (> 0), nom, cognom i saldo.");
         }
       }
     }

     public void tancarArxiu() {

       if (sortida != null) {
         sortida.close();
       }
     }
   }


   public class ProvaCrearArxiuText {
 
     public static void main(String args[]) throws FileNotFoundException {

       CrearArxiuText aplicacio = new CrearArxiuText();
       aplicacio.obrirArxiu();
       aplicacio.agregarRegistres();
       aplicacio.tancarArxiu();
     }
   }

La sentència throws FileNotFoundException que apareix en els dos fitxers anterior, està indicant que es pot produir una excepció de fitxer no trobat. Quan treballem amb fitxers es poden produir diferents tipus d'excepcions ( fitxer no trobat, falta de permisos, etc) que fa que el programa no funcioni amb normalitat. És responsabilitat del programador gestionar aquestes excepcions. Aquí no ho estem fent ja que el tema de control d'excepcions es veu més endavant, però cal tenir clar que la forma com es presenta el codi en aquests exemples NO és la forma correcta de fer-ho.

Lectura de dades d’un arxiu de text seqüencial