Diferència entre revisions de la pàgina «M3 - Programació estructurada / Continguts UF3: Fitxers de text»

De wikiserver
Dreceres ràpides: navegació, cerca
(Creació d’un arxiu de text d’accés seqüencial)
(Creació d’un arxiu de text d’accés seqüencial)
Línia 21: Línia 21:
 
:*Es crea amb la ruta del arxiu.  
 
:*Es crea amb la ruta del arxiu.  
 
<pre>
 
<pre>
sortida = new Formatter("clients.txt"); //per defecte els arxius es troben en el directori des del qual es va executar el programa.
+
sortida = new Formatter("clients.txt");  
                                        //Si l'arxiu no existeix, es crearà.
 
 
</pre>
 
</pre>
  
Línia 31: Línia 30:
 
::*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.
 
::*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.
  
 +
'''Mètode format'''
  
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.
+
:*Pot efectuar un format idèntic al del mètode '''System.out.printf'''.
 +
:*Envia una cadena amb format a la destinació de sortida de l'objecte Formatter
 +
:*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.  
 +
:*El valor del 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.
  
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.
+
'''Mètode close'''
  
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.
+
:*Tanca l'objecte Formatter i l'arxiu de sortida subjacent.
 +
:*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.
  
 
<pre>
 
<pre>
Línia 92: Línia 98:
 
</pre>
 
</pre>
  
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.
+
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===
 
===Lectura de dades d’un arxiu de text seqüencial===

Revisió del 11:27, 8 feb 2018

Arxius de text seqüencials

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

Exemple: arxiu de comptes pendents de cobrament. Les dades obtingudes per a cada client constitueixen un “registre” per a aquest client. 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;        //número de compte. s'utilitza com a clau principal. L'arxiu s'ordena segons aquest número.
     String nom;
     String cognom;
     double saldo;
   }

Formatter

  • Objecte que permet enviar dades a diverses ubicacions, com la pantalla o a un arxiu.
  • Es crea amb la ruta del arxiu.
sortida = new Formatter("clients.txt"); 

Consideracions:

  • Per defecte els arxius es troben 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.

Mètode format

  • Pot efectuar un format idèntic al del mètode System.out.printf.
  • Envia una cadena amb format a la destinació de sortida de l'objecte Formatter
  • 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.
  • El valor del 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.

Mètode close

  • Tanca l'objecte Formatter i l'arxiu de sortida subjacent.
  • 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

L'aplicació de següent llegeix registres de l'arxiu "clients.txt" creat per l'aplicació anterior i mostra el contingut dels registres. Es declara un objecte Scanner, que s'utilitzarà per obtenir les dades d'entrada de l'arxiu. El mètode obrirArxiu obre l'arxiu en manera de lectura. Passem un objecte File al constructor, el qual especifica que l'objecte Scanner llegirà dades de l'arxiu "clients.txt" situat en el directori des del qual s'executa l'aplicació. Si no pot trobar-se l'arxiu, ocorre una excepció.

El mètode llegirRegistres llegeix i mostra registres de l'arxiu.

Es llegeixen dades de l'arxiu fins a arribar al marcador de fi d'arxiu (en aquest cas, el mètode hasNext retornarà fals). Cada registre és una línia de dades en l'arxiu. Si no ocorren excepcions, la informació del registre es mostra en pantalla. Cada iteració del cicle introdueix una línia de text de l'arxiu de text, la qual representa un registre.

   public class LlegirArxiuText {

     private Scanner entrada;

     public void obrirArxiu() throws FileNotFoundException {

       entrada = new Scanner(new File("clients.txt"));
     }

     public void llegirRegistres() {

       System.out.printf("%-9s%-15s%-18s%10s\n","Compte","Nom","Cognom","Saldo");
       while (entrada.hasNext()) {
         int compte = entrada.nextInt();
         String nom = entrada.next();
         String cognom = entrada.next();
         double saldo = entrada.nextDouble();
         System.out.printf("%-9d%-15s%-18s%10.2f\n",compte, nom, cognom, saldo);
       }
     }

     public void tancarArxiu() {

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


   public class ProvaLLegirArxiuText {

     public static void main(String[] args) {

       LlegirArxiuText l= new LlegirArxiuText();
       l.obrirArxiu();
       l.llegirRegistres();
       l.tancarArxiu();
     }
   }