User Tools

Site Tools


java:formatting

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
java:formatting [2020/03/09 08:19] – [Η μέθοδος format] gthanosjava:formatting [Unknown date] (current) – external edit (Unknown date) 127.0.0.1
Line 1: Line 1:
-====== Μορφοποίηση Εξόδου ======+====== Εγγραφή σε αρχεία κείμενου ======
  
-**Σημείωση:** Τα μόνα //PrintStream// αντικείμενα που είναι πιθανό να χρειαστείτε είναι τα //System.out// και //System.err//. Όταν χρειάζεται να δημιουργήσετε ένα διαμορφωμένο stream εξόδου, χρησιμοποιήστε //PrintWriter//, και όχι //PrintStream//+Η εγγραφή αρχείων κειμένου γίνεται μέσω της κλάσης [[https://docs.oracle.com/javase/8/docs/api/java/io/PrintWriter.html|PrintWriter]]. Προκειμένου να γράψετε σε ένα αρχείο θα πρέπει να δημιουργήσετε ένα αντικείμενο αυτής της κλάσης με όρισμα το όνομα του αρχείου στο οποίο θέλετε να γράψετε. Εάν το αρχείο υπάρχει τα περιεχόμενα του θα διαγραφούν.
  
-Οι κλάσεις [[http://docs.oracle.com/javase/7/docs/api/java/io/PrintStream.html|PrintStream]] και [[http://docs.oracle.com/javase/7/docs/api/java/io/PrintWriter.html|PrintWriter]] υλοποιούν ένα κοινό σύνολο μεθόδων για εγγραφή χαρακτήρων. Δύο βασικές δυνατότητες μορφοποίησης παρέχονται:+Στο παρακάτω παράδειγμα, η κλάση ReadWithScanner της προηγούμενης ενότητας επεκτείνεται με μία επιπλέον μέθοδο για την εγγραφή των περιεχομένων του πίνακα των τηλεφωνικών αριθμών σε ένα αρχείο τύπου [[wiki:Comma-separated_values|CSV]] (Comma Separated Values). Παρατηρήστε ότι για να ανοίξουμε ένα αρχείο για εγγραφή μέσω της κλάσης PrintWriter θα πρέπει αυτό να γίνει μέσα σε ένα try block (ή try-with-resources block) και θα πρέπει να διαχειριστούμε το [[https://docs.oracle.com/javase/8/docs/api/java/io/FileNotFoundException.html|java.io.FileNotFoundException]]. 
 + 
 +<code java ReadWithScannerAndWriteCSV.java> 
 +import java.util.*; 
 +import java.io.*; 
 + 
 +public class ReadWithScannerAndWriteCSV { 
 + 
 + 
 +  public static void main(String []args) { 
 +   
 +    TelephoneNumber[] numbers; 
 +    numbers = readTelephoneNumbers("telephone-list.txt"); 
 +    printTelephoneNumbers(numbers); 
 +    writeTelephoneNumbers2CSVfile(numbers, "contacts.csv"); 
 +  } 
 +   
 +  public static void printTelephoneNumbers(TelephoneNumber[] numbers) { 
 +    for(TelephoneNumber number : numbers) { 
 +      System.out.println(number); 
 +    } 
 +  } 
 +   
 +  public static TelephoneNumber[] readTelephoneNumbers(String filename) { 
 +    String firstname, lastname; 
 +     
 +    long number; 
 +    int i=0; 
 +    TelephoneNumber numbers[] = new TelephoneNumber[5]; 
 +    try(Scanner sc = new Scanner(new File(filename))) { 
 +       
 +      while( sc.hasNext() ) {         
 +        firstname = sc.next(); 
 +        lastname = sc.next(); 
 +        number = sc.nextLong(); 
 + 
 +        numbers[i++] = new TelephoneNumber(firstname+" "+lastname, number); 
 +      } 
 +       
 +    } catch(InputMismatchException ex) { 
 +      System.out.println("Invalid file contents!"); 
 +    } catch(FileNotFoundException ex) { 
 +      System.out.println("Unable to open '"+filename+"'"); 
 +    } 
 +     
 +    return numbers; 
 +  } 
 +   
 +  public static void writeTelephoneNumbers2CSVfile(TelephoneNumber[] numbers, String filename) { 
 +     
 +    try(PrintWriter writer = new PrintWriter(filename)) { 
 +      for(TelephoneNumber number : numbers) { 
 +        writer.format("%d, %s\n", number.getNumber(), number.getName()); 
 +      } 
 +    } 
 +    catch(FileNotFoundException ex) { 
 +      System.out.format("Unable to open file '%s' for writting!\n", filename); 
 +    } 
 +     
 +  } 
 +
 +</code> 
 + 
 +Η κλάση [[https://docs.oracle.com/javase/8/docs/api/java/io/PrintWriter.html|PrintWriter]], όπως και η κλάση [[https://docs.oracle.com/javase/8/docs/api/java/io/PrintStream.html|PrintStream]] παρέχουν τη μέθοδο format (ή printf) για την εκτύπωση μορφοποιημένης εξόδου. Η έννοια της μορφοποιημένες εξόδου εξηγείται παρακάτω και εφαρμόζεται τόσο σε αρχεία όσο και σε εκτύπωση στην κονσόλα. 
 + 
 +===== Μορφοποίηση Εξόδου ===== 
 + 
 +Οι κλάσεις [[http://docs.oracle.com/javase/7/docs/api/java/io/PrintStream.html|PrintStream]] και [[http://docs.oracle.com/javase/7/docs/api/java/io/PrintWriter.html|PrintWriter]] υλοποιούν ένα κοινό σύνολο μεθόδων για εγγραφή χαρακτήρων. Παρέχονται οι παρακάτω δύο δυνατότητες μορφοποίησης:
  
   - Οι μέθοδοι //print// και //println// οι οποίες δέχονται μόνο ένα όρισμα είτε βασικού τύπου (int, long, double, byte etc), είτε αναφορικού τύπου ([[http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html|Object]] ή [[http://docs.oracle.com/javase/7/docs/api/java/lang/String.html|String]])   - Οι μέθοδοι //print// και //println// οι οποίες δέχονται μόνο ένα όρισμα είτε βασικού τύπου (int, long, double, byte etc), είτε αναφορικού τύπου ([[http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html|Object]] ή [[http://docs.oracle.com/javase/7/docs/api/java/lang/String.html|String]])
Line 11: Line 78:
  
 Η κλήση των //print// ή //println// απαιτεί την εκτύπωση ενός αλφαριθμητικού. Εάν το όρισμα που λαμβάνουν οι μέθοδοι αυτές δεν είναι αλφαριθμητικό τότε  Η κλήση των //print// ή //println// απαιτεί την εκτύπωση ενός αλφαριθμητικού. Εάν το όρισμα που λαμβάνουν οι μέθοδοι αυτές δεν είναι αλφαριθμητικό τότε 
-  * για αναφορικούς τύπους που δεν είναι Striung καλείται η μέθοδος ''toString()'', προκειμένου να μετατραπούν τα ορίσματα σε String. +  * για αναφορικούς τύπους που δεν είναι String καλείται η μέθοδος ''toString()'', προκειμένου να μετατραπούν τα ορίσματα σε String. 
   * για βασικούς τύπους, αυτοί μετατρέπονται πρώτα σε αναφορικούς (int --> [[http://docs.oracle.com/javase/7/docs/api/java/lang/Integer.html|Integer]], long --> [[http://docs.oracle.com/javase/7/docs/api/java/lang/Long.html|Long]]) και στη συνέχεια καλείται η μέθοδος ''toString'' για αυτούς.   * για βασικούς τύπους, αυτοί μετατρέπονται πρώτα σε αναφορικούς (int --> [[http://docs.oracle.com/javase/7/docs/api/java/lang/Integer.html|Integer]], long --> [[http://docs.oracle.com/javase/7/docs/api/java/lang/Long.html|Long]]) και στη συνέχεια καλείται η μέθοδος ''toString'' για αυτούς.
  
Line 79: Line 146:
 public class MyFormat { public class MyFormat {
     public static void main(String[] args) {     public static void main(String[] args) {
-        System.out.format("%f, %1$+020.10f %n", Math.PI);+        System.out.format("%f, 020.10f %n", Math.PI);
     }     }
 } }
Line 118: Line 185:
  
  
-|Προηγούμενο: [[:java:util_scanner_class | Η κλάση Scanner]] | [[:toc | Περιεχόμενα ]] | Επόμενο: [[:java:class_path Η κλάση Path ]] |+|Προηγούμενο: [[:java:util_scanner_class | Η κλάση Scanner]] | [[:toc | Περιεχόμενα ]] | Επόμενο: [[:java:object_serialization Object Serialization/Deserialization ]] |
  
  
java/formatting.1583741997.txt.gz · Last modified: 2020/03/09 08:19 (external edit)