Szukaj…


Odczytywanie danych wejściowych użytkownika z konsoli

Za pomocą BufferedReader :

System.out.println("Please type your name and press Enter.");

BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
try {
    String name = reader.readLine();
    System.out.println("Hello, " + name + "!");
} catch(IOException e) {
    System.out.println("An error occurred: " + e.getMessage());
}

Do tego kodu potrzebne są następujące importy:

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

Za pomocą Scanner :

Java SE 5
System.out.println("Please type your name and press Enter");

Scanner scanner = new Scanner(System.in);
String name = scanner.nextLine();

System.out.println("Hello, " + name + "!");

W tym przykładzie potrzebny jest następujący import:

import java.util.Scanner;

Aby odczytać więcej niż jedną linię, scanner.nextLine() :

System.out.println("Please enter your first and your last name, on separate lines.");
    
Scanner scanner = new Scanner(System.in);
String firstName = scanner.nextLine();
String lastName = scanner.nextLine();
    
System.out.println("Hello, " + firstName + " " + lastName + "!");

Istnieją dwie metody uzyskiwania Strings , next() i nextLine() . next() zwraca tekst do pierwszej spacji (znanej również jako „token”), a nextLine() zwraca cały tekst wprowadzony przez użytkownika do momentu naciśnięcia enter.

Scanner zapewnia również narzędzia do odczytu typów danych innych niż String . Obejmują one:

scanner.nextByte();
scanner.nextShort();
scanner.nextInt();
scanner.nextLong();
scanner.nextFloat();
scanner.nextDouble();
scanner.nextBigInteger();
scanner.nextBigDecimal();

Prefiksowanie dowolnej z tych metod za pomocą has (jak w hasNextLine() , hasNextInt() ) zwraca wartość true jeśli strumień ma więcej typów żądań. Uwaga: Te metody spowodują awarię programu, jeśli dane wejściowe nie są żądanego typu (na przykład wpisanie „a” dla nextInt() ). Możesz użyć try {} catch() {} aby temu zapobiec (patrz: Wyjątki )

Scanner scanner = new Scanner(System.in); //Create the scanner
scanner.useLocale(Locale.US); //Set number format excepted
System.out.println("Please input a float, decimal separator is .");
if (scanner.hasNextFloat()){ //Check if it is a float
    float fValue = scanner.nextFloat(); //retrive the value directly as float
    System.out.println(fValue + " is a float");
}else{
    String sValue = scanner.next(); //We can not retrive as float
    System.out.println(sValue + " is not a float");
}

Za pomocą System.console :

Java SE 6
String name = System.console().readLine("Please type your name and press Enter%n");

System.out.printf("Hello, %s!", name);

//To read passwords (without echoing as in unix terminal)
char[] password = System.console().readPassword();

Zalety :

  • Metody czytania są zsynchronizowane
  • Można użyć składni formatu ciągu

Uwaga : Działa to tylko wtedy, gdy program jest uruchamiany z rzeczywistego wiersza poleceń bez przekierowywania standardowych strumieni wejściowych i wyjściowych. Nie działa, gdy program jest uruchamiany z określonych środowisk IDE, takich jak Eclipse. Kod, który działa w ramach IDE i z przekierowaniem strumienia, zobacz inne przykłady.

Wdrażanie podstawowego zachowania wiersza polecenia

W przypadku podstawowych prototypów lub podstawowego zachowania wiersza polecenia przydatna jest następująca pętla.

public class ExampleCli {

    private static final String CLI_LINE   = "example-cli>"; //console like string

    private static final String CMD_QUIT   = "quit";    //string for exiting the program
    private static final String CMD_HELLO  = "hello";    //string for printing "Hello World!" on the screen
    private static final String CMD_ANSWER = "answer";    //string for printing 42 on the screen

    public static void main(String[] args) {
        ExampleCli claimCli = new ExampleCli();    // creates an object of this class

        try {
            claimCli.start();    //calls the start function to do the work like console
        }
        catch (IOException e) {
            e.printStackTrace();    //prints the exception log if it is failed to do get the user input or something like that
        }
    }

    private void start() throws IOException {
        String cmd = "";
        
        BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
        while (!cmd.equals(CMD_QUIT)) {    // terminates console if user input is "quit"
            System.out.print(CLI_LINE);    //prints the console-like string 

            cmd = reader.readLine();    //takes input from user. user input should be started with "hello",  "answer" or "quit"
            String[] cmdArr = cmd.split(" ");

            if (cmdArr[0].equals(CMD_HELLO)) {    //executes when user input starts with "hello"
                hello(cmdArr);
            }
            else if (cmdArr[0].equals(CMD_ANSWER)) {    //executes when user input starts with "answer"
                answer(cmdArr);
            }
        }
    }
    
    // prints "Hello World!" on the screen if user input starts with "hello"
    private void hello(String[] cmdArr) {
        System.out.println("Hello World!");
    }
    
    // prints "42" on the screen if user input starts with "answer"
    private void answer(String[] cmdArr) {
        System.out.println("42");
    }
}

Wyrównanie ciągów w konsoli

Metoda PrintWriter.format (wywoływana przez System.out.format ) może być używana do drukowania wyrównanych ciągów w konsoli. Metoda otrzymuje String z informacją o formacie i serią obiektów do sformatowania:

String rowsStrings[] = new String[] {"1", 
                                     "1234", 
                                     "1234567", 
                                     "123456789"};

String column1Format = "%-3s";    // min 3 characters, left aligned
String column2Format = "%-5.8s";  // min 5 and max 8 characters, left aligned
String column3Format = "%6.6s";   // fixed size 6 characters, right aligned
String formatInfo = column1Format + " " + column2Format + " " + column3Format;

for(int i = 0; i < rowsStrings.length; i++) {
    System.out.format(formatInfo, rowsStrings[i], rowsStrings[i], rowsStrings[i]);
    System.out.println();
}

Wynik:

1   1          1
1234 1234    1234
1234567 1234567 123456
123456789 12345678 123456

Używanie ciągów formatu o stałym rozmiarze pozwala na drukowanie ciągów w formie tabeli z kolumnami o stałym rozmiarze:

String rowsStrings[] = new String[] {"1", 
                                     "1234", 
                                     "1234567", 
                                     "123456789"};

String column1Format = "%-3.3s";  // fixed size 3 characters, left aligned
String column2Format = "%-8.8s";  // fixed size 8 characters, left aligned
String column3Format = "%6.6s";   // fixed size 6 characters, right aligned
String formatInfo = column1Format + " " + column2Format + " " + column3Format;

for(int i = 0; i < rowsStrings.length; i++) {
    System.out.format(formatInfo, rowsStrings[i], rowsStrings[i], rowsStrings[i]);
    System.out.println();
}

Wynik:

1   1             1
123 1234       1234
123 1234567  123456
123 12345678 123456

Przykłady formatowania ciągów

  • %s : tylko ciąg bez formatowania
  • %5s : sformatuj ciąg przy użyciu co najmniej 5 znaków; jeśli ciąg jest krótszy, zostanie dopełniony do 5 znaków i wyrównany do prawej
  • %-5s : sformatuj ciąg przy użyciu co najmniej 5 znaków; jeśli ciąg jest krótszy, zostanie dopełniony do 5 znaków i wyrównany do lewej
  • %5.10s : sformatuj ciąg przy użyciu co najmniej 5 znaków i maksymalnie 10 znaków; jeśli łańcuch jest krótszy niż 5, zostanie uzupełniony do 5 znaków i wyrównany do prawej ; jeśli ciąg jest dłuższy niż 10, zostanie obcięty do 10 znaków i wyrównany do prawej
  • %-5.5s : sformatuj ciąg o stałym rozmiarze 5 znaków (minimum i maksimum są równe); jeśli łańcuch jest krótszy niż 5, zostanie uzupełniony do 5 znaków i wyrównany do lewej ; jeśli ciąg jest dłuższy niż 5, zostanie obcięty do 5 znaków i wyrównany do lewej


Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow