Java: Textový vstup a výstup
Z MiS
(Rozdíly mezi verzemi)
m (→Zápis do souboru (BufferedWriter): Charset.forName(...) byla špatně.) |
(Doplněna informace, že problém se Scannerem lze obejít uložením v UTF-8.) |
||
Řádka 51: | Řádka 51: | ||
Narazili jsme na problém, že třída Scanner se při ladění v prostředí NetBeans 8.0.2 (JDK 7u71) chovala se k souboru, jako by byl prázdný. | Narazili jsme na problém, že třída Scanner se při ladění v prostředí NetBeans 8.0.2 (JDK 7u71) chovala se k souboru, jako by byl prázdný. | ||
− | Pokud máte podobné problémy, zkuste projekt přeložit a spustit přímo výsledný JAR | + | Pokud máte podobné problémy, zkuste: |
+ | |||
+ | a) uložte vstupní soubor v kódování UTF-8 (třeba pomocí Notepadu++ či jiného editoru, který umí nastavit kódování). S kódováním ANSI má debugger v Netbeans, zdá se, problém. | ||
+ | |||
+ | b) projekt přeložit (''Clean & Build'') a spustit přímo výsledný JAR ze složky <code>dist</code> v adresáři projektu. ([[Java:_Export_bal%C3%AD%C4%8Dku_JAR#Export_z_NetBeans|viz Export balíčku JAR]]). | ||
</div> | </div> | ||
<div class="Varovani">Třídu Scanner nepoužívejte v programech, které pracují s [[Vlákna v Javě|vlákny]]!</div> | <div class="Varovani">Třídu Scanner nepoužívejte v programech, které pracují s [[Vlákna v Javě|vlákny]]!</div> |
Verze z 23. 4. 2018, 07:13
Obsah |
Zápis do souboru (BufferedWriter)
Třída BufferedWriter
slouží pro zápis dat do textového výstupu.
- Princip
- Ukládá zapisovaná data do paměťového bufferu.
- Teprve při dosažení limitu data naráz zapíše.
- Je to efektivnější, než psát jednotlivé malé texty hned!
- Otevření standardního výstupu
BufferedWriter out = new BufferedWriter(new OutputStreamWriter(System.out));
Tuto variantu používáme tehdy, kdy chceme společnou metodu pro psaní do souboru i na standardní výstup. Pro standardní výstup jinak samozřejmě stačí:
System.out.println(...);
- Otevření souboru
Charset kodovani = Charset.forName("utf-8"); Path cesta = Paths.get("vystup.txt"); BufferedWriter out = Files.newBufferedWriter(cesta, kodovani);
Související třídy:
- Charset
- informace o kódování souboru
- Files, Paths
- práce s cestami a soubory
- umí i otevřít BufferedWriter.
- Metody
-
write(String text)
-
newLine()
- Přidá do výstupu konec řádku. Respektuje národní nastavení a platformové závislosti.
-
flush()
- Provede fyzický zápis stávajícího obsahu bufferu na výstup.
-
close()
- Zavře výstupní soubor.
- Provede i
flush()
.
Charset kodovani = Charset.forName("utf-8"); Path cesta = Paths.get("vystup.txt"); BufferedWriter out = Files.newBufferedWriter(cesta, kodovani); out.write("blabla"); out.newLine(); out.close();
Vstup (Scanner)
- Třída
Scanner
slouží ke čtení z textového vstupu — z klávesnice nebo z textového souboru. - Zaveden od Javy 5 — nahrazuje BufferedReader.
Narazili jsme na problém, že třída Scanner se při ladění v prostředí NetBeans 8.0.2 (JDK 7u71) chovala se k souboru, jako by byl prázdný.
Pokud máte podobné problémy, zkuste:
a) uložte vstupní soubor v kódování UTF-8 (třeba pomocí Notepadu++ či jiného editoru, který umí nastavit kódování). S kódováním ANSI má debugger v Netbeans, zdá se, problém.
b) projekt přeložit (Clean & Build) a spustit přímo výsledný JAR ze složky dist
v adresáři projektu. (viz Export balíčku JAR).
Třídu Scanner nepoužívejte v programech, které pracují s vlákny!
- Metody
-
next()
- přečte celý řádek až po oddělovač (viz dále)
- při čtení z konzole (klávesnice) čeká na oddělovač
- bere jednotlivá slova, oddělená standardně bílým místem
-
int nextInt()
-
int nextDouble()
- vrací objektový typ Double.
- Desetinná čísla je třeba zadávat podle národního nastavení. Pro české nastavení tedy s desetinnou čárkou.
-
boolean hasNext()
- je k dispozici další slovo?
-
boolean hasNextDouble()
- následuje na vstupu desetinné číslo?
-
useDelimiter(String delim)
, resp.useDelimiter(Pattern delim)
- Oddělovač položek na řádku, například:
out.useDelimiter(",");
- Jako oddělovač lze použít i regulární výraz (→ Wikipedia.org) reprezentovaný třídou
Pattern
. - Pro načítání jednoduchého CSV lze použít (pozor, není to plnohodnotné čtení CSV, ale mnohdy stačí):
- Oddělovač položek na řádku, například:
out.useDelimiter("\\s*[;,\n\r\t]\\s*")
- Otevření vstupu
- Standardní vstup
Scanner sc = new Scanner(System.in); int i = sc.nextInt(); vstup=input.next();
- Ze souboru:
Scanner sc = new Scanner(new File("myNumbers")); while (sc.hasNextLong()) { ... long aLong = sc.nextLong(); ... }
Standardní vstup a výstup
- Unixové programy a programy pro textový řádek často potřebují číst data ze standardního vstupu (běžně klávesnice) a zapisovat data na standardní výstup (běžně monitor).
- Pro základní práci mnohdy stačí přímo pracovat se standardním vstupem a výstupem přímo:
- System.out
- Běžně používáme pro výstup do konzole:
System.out.print("Ahoj!"); System.out.println("Vypíše řádek na obrazovku!");
- System.in
- Vyžaduje práci s vyjímkami (může vyhodit IOException), je tedy lepší použít třídu Scanner, pokud to lze.
- Čekání na stisk Enteru:
System.in.read();
- Test stisku libovolné klávesy:
System.in.available() > 0
Viz také