Vstup a výstup procesů, přesměrování

Z MiS
(Rozdíly mezi verzemi)
Přejít na: navigace, hledání
(Filtr grep: Doplněna kapitola)
(Přidány další úkoly, doplněno řešení některých úkolů - ostatní dodělat.)
(Není zobrazeno 11 mezilehlých verzí od 1 uživatele.)
Řádka 1: Řádka 1:
[[Category:VSE]][[Category:Informatika]][[Category:Linux]][[Category:OSY]]
+
[[Category:VSE]][[Category:Informatika]][[Category:Linux]][[Category:OSY]][[Category:Příkazový řádek]]
  
 
<div class="Motto">
 
<div class="Motto">
Řádka 62: Řádka 62:
 
  cat /etc/passwd | cut -d : -f 1 | sort
 
  cat /etc/passwd | cut -d : -f 1 | sort
  
 +
<div class="Poznamka">Poznámka: Funkci použitých příkazů najdete v kapitole [[#Filtry]].</div>
  
 
; Další příklady
 
; Další příklady
Řádka 69: Řádka 70:
 
  cat /proc/meminfo | grep Free
 
  cat /proc/meminfo | grep Free
 
  cat /etc/passwd | grep student
 
  cat /etc/passwd | grep student
 
  
 
== Speciální soubory ==
 
== Speciální soubory ==
Řádka 107: Řádka 107:
 
* <code>sort</code>
 
* <code>sort</code>
 
  cat /etc/passwd | cut -d : -f 1,5 | sort
 
  cat /etc/passwd | cut -d : -f 1,5 | sort
* <code>cut</code>... vybere jen některé sloupce z&nbsp;tabulky. Viz [[#Filtr <code>cut</code>|samostatná kapitolka]].
+
* <code>cut</code>... vybere jen některé sloupce z&nbsp;tabulky. Viz [[#Filtr cut|samostatná kapitolka]].
 +
* <code>nl</code>... očísluje řádky výstupu (šikovné u zdrojových kódů skriptů).
 
* <code>tee</code>... opisuje vstup na obrazovku i do souboru či do dvou souborů
 
* <code>tee</code>... opisuje vstup na obrazovku i do souboru či do dvou souborů
 
  $ date | tee file1 file2   
 
  $ date | tee file1 file2   
Řádka 117: Řádka 118:
 
** Nahrazuje ve vstupu zadané znaky jinými (podle tabulky) a vypisuje na výstup.
 
** Nahrazuje ve vstupu zadané znaky jinými (podle tabulky) a vypisuje na výstup.
  
 +
; Úkoly:
 +
* Vypište druhý řádek ze souboru <code>/proc/meminfo</code>.
  
 
== Hrátky &mdash; filtr <tt>cat</tt>;) ==
 
== Hrátky &mdash; filtr <tt>cat</tt>;) ==
Řádka 142: Řádka 145:
 
; Příklady použití:
 
; Příklady použití:
 
  ls | grep a.[0-9]\.jpg
 
  ls | grep a.[0-9]\.jpg
* Akceptuje soubory: <tt>ab.jpg</tt>, <tt>a19.jpg</tt>, <tt>az0.jpg</tt>, <tt>a.0.jpg</tt>  
+
* Akceptuje soubory: <tt>ab3.jpg</tt>, <tt>a19.jpg</tt>, <tt>az0.jpg</tt>, <tt>a.0.jpg</tt>  
* Ale neakceptuje soubory: <tt>a.jpg</tt>, <tt>a1u.jpg</tt>, <tt>a19.jpg</tt>, <tt>a.72jpg</tt>
+
* Ale neakceptuje soubory: <tt>ab.jpg</tt>, <tt>a.jpg</tt>, <tt>a1u.jpg</tt>, <tt>a9i.jpg</tt>, <tt>a.72jpg</tt>
  
Více viz třeba: [http://www.regularnivyrazy.info/regularni-vyrazy-zaklady.html#.VNMYomOb_q8 Regulární výrazy.info]
+
; Úkoly
 +
* Vypište ze souboru <code>/etc/passwd</code> řádek, který se týká aktuálně přihlášeného uživatele.
  
 
== Filtr <code>cut</code> ==
 
== Filtr <code>cut</code> ==
 +
* Na vstupu očekává textově zapsanou tabulku (podobný formát jako u souborů CSV).
 +
* Vybere jen zvolené sloupce z „tabulky“.
  
 +
; Parametry:
 +
-d :
 +
* Zadává oddělovač jednotlivých „buněk tabulky“.
 +
-f 1,3
 +
* Zadává, které „sloupce“ z tabulky se mají vypsat.
 +
 +
; Příklad:
 +
* Typickým příkladem je práce se [[Konfigura%C4%8Dn%C3%AD_soubory_GNU/Linuxu_-_U%C5%BEivatelsk%C3%A9_%C3%BA%C4%8Dty|souborem <tt>/etc/passwd</tt>]].
 +
* Soubor <tt>/etc/passwd</tt> obsahuje údaje o uživatelích. Na každém řádku je jeden uživatel, údaje jsou odděleny znakem <tt>:</tt>.
 +
 +
cut /etc/passwd -d : -f 1,6
 +
* Vypíše na obrazovku seznam uživatelských účtů a domovské složky uživatelů.
 +
* Jedná se o sloupečky 1 a 6 z souboru <tt>/etc/passwd</tt>. Oddělovačem je standardně dvojtečka.
  
 
== Zopakujte si ==
 
== Zopakujte si ==
Řádka 158: Řádka 177:
  
 
== Vyzkoušejte si ==
 
== Vyzkoušejte si ==
* Vypište obsah adresáře do souboru <tt>vypis.txt</tt>.
+
* Vypište obsah aktuálního adresáře do souboru <tt>vypis.txt</tt>.
* Spočtěte, kolik souborů a složek je v adresáři.
+
* Spočtěte, kolik souborů a složek je v podadresáři <tt>etc</tt> kořenového adresáře.
* V předchozím úkolu zahrňte jen soubory obsahující písmeno ''w''.
+
* V předchozím úkolu zahrňte jen soubory obsahující v&nbsp;názvu písmeno ''w''.
* Výsledek předchozího úkolu připojte na nový rádek do souboru <tt>vypis.txt</tt>.
+
* Výsledek předchozího úkolu připojte na nový řádek do souboru <tt>vypis.txt</tt>.
 
* Zobrazte seznam souborů v adresáři <tt>/bin</tt>. Pokud se výpis nevleze na obrazovku, zařiďte, aby se vypsala jen první obrazovka a výpisem šlo listovat (nahoru, dolů, o celé stránky, vyhledávat).
 
* Zobrazte seznam souborů v adresáři <tt>/bin</tt>. Pokud se výpis nevleze na obrazovku, zařiďte, aby se vypsala jen první obrazovka a výpisem šlo listovat (nahoru, dolů, o celé stránky, vyhledávat).
* Vypište uživatelská jména uživatelů registrovaných v systému s GNU/Linuxem. Každé jméno na jeden řádek.
+
* Vypište posledních 5&nbsp;souborů podle abecedy z&nbsp;podadresáře <tt>proc</tt> kořenového adresáře.
 +
* Vypište ty řádky souboru <tt>cpuinfo</tt> podadresáře <tt>proc</tt> kořenového adresáře, které obsahují slovo ''model''.
 +
* Vypište uživatelská jména uživatelů registrovaných v systému s GNU/Linuxem. Každé jméno na jeden řádek. Jména seřaďte podle abecedy sestupně.
  
  
 
== Úkoly ==
 
== Úkoly ==
# Proč nefunguje tento postup? Opravte:
+
; Úkol 1. &mdash; Formátovaný výstup:
#* Výběr uživatelů se správnou doménou:
+
* Napište posloupnost příkazů, která vytvoří soubor ve tvaru:
 +
*# Několik pomlček
 +
*# Text <code>"Adresář:"</code>
 +
*# Cesta k aktuálnímu adresáři
 +
*# Text <code>"Obsahuje soubory:"</code>
 +
*# Výpis souborů, které jsou v aktuálním adresáři.
 +
* Příklad výstupu:
 +
---------------
 +
Adresář:
 +
''/home/student''
 +
obsahuje soubory:
 +
''Desktop''
 +
''Downloads''
 +
''a.txt''
 +
----------------
 +
 
 +
; Úkol 2. &mdash; Špatné filtrování?
 +
* Chci vybrat z textového souboru uživatele s jednou konkrétní doménou (<code>seznam.cz</code>).
 +
* Proč nefunguje tento postup:
 
  echo Eduard; Karásek; karaed@seznam.cz; 48 > data.txt
 
  echo Eduard; Karásek; karaed@seznam.cz; 48 > data.txt
 
  echo Karel; Seznamicz; karel@seznamicz.cr; 25 >> data.txt
 
  echo Karel; Seznamicz; karel@seznamicz.cr; 25 >> data.txt
 
  echo Jana; Dolanská; dolanska@centrum.cz; 37 >> data.txt
 
  echo Jana; Dolanská; dolanska@centrum.cz; 37 >> data.txt
 +
 
  cat data.txt | grep @seznam.cz
 
  cat data.txt | grep @seznam.cz
 +
* Opravte příkazy!
 +
 +
 +
== Řešení úkolů ==
 +
ls > vypis.txt
 +
ls /etc | wc -l
 +
ls /etc | grep w | wc -l
 +
 +
* Výsledek předchozího úkolu připojte na nový řádek do souboru <tt>vypis.txt</tt>.
 +
* Zobrazte seznam souborů v adresáři <tt>/bin</tt>. Pokud se výpis nevleze na obrazovku, zařiďte, aby se vypsala jen první obrazovka a výpisem šlo listovat (nahoru, dolů, o celé stránky, vyhledávat).
 +
* Vypište posledních 5&nbsp;souborů podle abecedy z&nbsp;podadresáře <tt>proc</tt> kořenového adresáře.
 +
* Vypište ty řádky souboru <tt>cpuinfo</tt> podadresáře <tt>proc</tt> kořenového adresáře, které obsahují slovo ''model''.
 +
* Vypište uživatelská jména uživatelů registrovaných v systému s GNU/Linuxem. Každé jméno na jeden řádek. Jména seřaďte podle abecedy sestupně.
 +
 +
 +
== Související stránky ==
 +
* [[Regulární výrazy]]
  
  
 
== Zdroje ==
 
== Zdroje ==
 
* [http://www.codecoffee.com/tipsforlinux/articles2/042.html codecoffee.com > Tips for Linux > Input/Output Redirection in Unix]
 
* [http://www.codecoffee.com/tipsforlinux/articles2/042.html codecoffee.com > Tips for Linux > Input/Output Redirection in Unix]

Verze z 22. 11. 2019, 09:47


„Write programs that do one thing and do it well.
  Write programs to work together.
  Write programs that handle text streams, because that is an universal interface.“

       Douglas McIlroy


Obsah

K čemu je přesměrování vstupů?


Procesy v Unixu a Linuxu

Přesměrování vstupů je vlastně způsob komunikace mezi procesy. Proces si můžeme představit jako černou skříňku s:

Vstup a výstup programů pak můžeme navzájem propojit.


Varianty přesměrování

Přesměrování standardního výstupu do souboru
ls -l > ~/obsah_adresare.txt
echo "Druhy adresar:" >> ~/obsah_adresare.txt
ls druhy -l >> ~/obsah_adresare.txt


Přesměrování chybového výstupu do souboru
cp a b 2> /dev/null
mv archiv.tar.gz zalohy 2> ~/zaloha_chyby.log


Přesměrování standardního vstupu


Propojení programů
ls | sort | head
cat /etc/passwd | cut -d : -f 1 | sort
Poznámka: Funkci použitých příkazů najdete v kapitole #Filtry.
Další příklady
cat /proc/meminfo
cat /proc/meminfo | head
cat /proc/meminfo | head -n 1 > memory.txt
cat /proc/meminfo | grep Free
cat /etc/passwd | grep student

Speciální soubory

Virtuální soubory reprezentující standardní vstup a výstup
Pomocné
cp ~/ahoj.txt /home/student/ahoj.txt 2> /dev/null

Viz také: Významné složky GNU/Linuxu.


Filtry

Jako filtr označujeme program, který čte data ze standardního vstupu a zapisuje výsledky na standardní výstup. Typické unixové programy se tedy chovají jako filtry.

tar --help | less
head -n 1 /proc/meminfo
tail /var/log/apache2/error_log
ls | wc -l
tar -c * | gzip > archiv.tar.gz
tar -czf archiv.tar.gz *
tar -xzf archiv.tar.gz
cat /etc/passwd | cut -d : -f 1,5 | sort
$ date | tee file1 file2   
Thu Jun 10 11:10:34 CEST 2004
$ cat file1   
Thu Jun 10 11:10:34 CEST 2004
Úkoly

Hrátky — filtr cat;)

cat
cat > /dev/stdout
cat > pokus.txt
cat /dev/stdin
cat < /etc/passwd


Filtr grep

Příklady použití
ls | grep a.[0-9]\.jpg
Úkoly

Filtr cut

Parametry
-d :
-f 1,3
Příklad
cut /etc/passwd -d : -f 1,6

Zopakujte si


Vyzkoušejte si


Úkoly

Úkol 1. — Formátovaný výstup
---------------
Adresář:
/home/student
obsahuje soubory:
Desktop
Downloads
a.txt
----------------
Úkol 2. — Špatné filtrování?
echo Eduard; Karásek; karaed@seznam.cz; 48 > data.txt
echo Karel; Seznamicz; karel@seznamicz.cr; 25 >> data.txt
echo Jana; Dolanská; dolanska@centrum.cz; 37 >> data.txt

cat data.txt | grep @seznam.cz


Řešení úkolů

ls > vypis.txt
ls /etc | wc -l
ls /etc | grep w | wc -l


Související stránky


Zdroje

Osobní nástroje
Jmenné prostory
Varianty
Akce
Výuka
Navigace
Nástroje