BASH: Žolíkové znaky: Porovnání verzí

Z Milan Kerslager
Přejít na: navigace, hledání
m (Stránka Žolíkové znaky, přesměrování, kolony přemístěna na stránku BASH: Žolíkové znaky: Reorganizace)
(Reorganizace)
Řádka 1: Řádka 1:
'''Žolíkové znaky, přesměrování a kolony''' jsou základním nástrojem, pomocí kterého se z [[Ovládání příkazového řádku v Unixu|příkazového řádku]] stává mocný a výkonný nástroj. [[Základní příkazy Unixu]] je možné používat flexibilně, kombinovat jejich schopnosti a spojovat jejich schopnosti do větších celků.
+
'''Žolíkové znaky''' slouží k tomu, aby nebylo nutné uvádět všechny parametry příkazů explicitně, ale bylo možné použít obecné zadání. Lze například pracovat se všemi soubory s příponou <code>txt</code> nebo se všemi, které vyhovují jiným podmínkám (začínají na určité znaky, obsahují slovo atd.).
 
 
== Žolíkové znaky ==
 
Žolíkové znaky slouží k tomu, aby nebylo nutné uvádět všechny parametry příkazy explicitně, ale bylo možné použít obecné zadání. Lze například pracovat se všemi soubory s příponou <code>txt</code> nebo se všemi, které vyhovují jiným podmínkám (začínají na určité znaky, obsahují slovo atd.).
 
  
 
:{| class=wikitable
 
:{| class=wikitable
Řádka 32: Řádka 29:
 
  ls /{bin,sbin}/c*    # vypíše z adresářů ''/bin'' a ''/sbin'' vše, co začíná na ''c''
 
  ls /{bin,sbin}/c*    # vypíše z adresářů ''/bin'' a ''/sbin'' vše, co začíná na ''c''
 
  ls /{,s}bin/c*        # vypíše z adresářů ''/bin'' a ''/sbin'' vše, co začíná na ''c''
 
  ls /{,s}bin/c*        # vypíše z adresářů ''/bin'' a ''/sbin'' vše, co začíná na ''c''
 
== Přesměrování ==
 
:{| class=wikitable
 
! Konstrukce
 
! Funkce
 
|-
 
| align=center | <code>&gt;</code>
 
| Přesměrování standardního výstupu (vytvoří nebo přemaže existující soubor)
 
|-
 
| align=center | <code>&gt;&gt;</code>
 
| Přesměrování standardního výstupu (vytvoří nebo přidá za konec existujícího souboru)
 
|-
 
| align=center | <code>&lt;</code>
 
| Přesměrování standardního vstupu
 
|-
 
| align=center | <code>2&gt;</code>
 
| Přesměrování do standardního chybového výstupu
 
|-
 
| align=center | <code>2&gt;&amp;1</code>
 
| Spojení standardního chybového výstupu se standardním výstupem
 
|-
 
| align=center | <code>1&gt;&amp;2</code>
 
| Spojení standardního výstupu se standardním chybovým výstupem (používá se při [[Programování v shellu BASH|programování skriptů]])
 
|-
 
| align=center | <code>&lt;&lt;MARK</code>
 
| Here document (používá se při [[Programování v shellu BASH|programování skriptů]])
 
|}
 
 
=== Příklady ===
 
Při přesměrování standardního výstupu pomocí znaku <code>&gt;</code> je existující soubor přepsán. Přesměrování pomocí <code>&gt;&gt;</code> přidává za konec existujícího souboru. V obou případech platí, že pokud soubor neexistuje, je vytvořen.
 
 
ls /bin > text.txt
 
echo kuk > text.txt
 
echo na strejdu >> text.txt
 
 
Většina programů považuje za svůj standardní vstup soubory, které jsou předány na příkazovém řádku jako parametry. Některé programy však toto vylepšení nemají implementováno a vždy předpokládají vstup na standardním vstupu. V následujícím příkladu je nejprve vytvořen soubor <code>text.txt</code> se dvěma řádky tak, že u příkazu <code>echo</code> je použit přepínač <code>-e</code>, který způsobí v tištěném řetězci interpretaci sekvence <code>\n</code> jako přechod na nový řádek. Následně je soubor <code>text.txt</code> převeden do formátu DOS/WINDOWS příkazem <code>unix2dos</code> a zaznamenán do souboru <code>dos.txt</code>.
 
 
/bin/echo -e "prvni\ndruhy" > text.txt
 
unix2dos < text.txt > dos.txt
 
 
''Poznámka:'' Pomocí příkazu <code>hexdump</code> je možné provést inspekci obou souborů a zjistit, že v unixovém souboru <code>text.txt</code> je zaznamenán řídící znak LF (hexadecimálně <code>0x0A</code>) a v převedeném souboru <code>dos.txt</code> je ve formátu DOS/WINDOWS používána sekvence CR/LF (<code>0x0D</code>, <code>0x0A</code>). V příkladu je tučně zvýrazněn vstup od uživatele a znak $ (dolar) reprezentuje výzvu shellu (prompt):
 
 
$ '''hexdump -C text.txt'''
 
00000000  70 72 76 6e 69 0a 64 72  75 68 79 0a              |prvni.druhy.|
 
0000000c
 
$ '''hexdump -C dos.txt'''
 
00000000  70 72 76 6e 69 0d 0a 64  72 75 68 79 0d 0a        |prvni..druhy..|
 
0000000e
 
 
Při dávkovém použití mohou rušit chybová hlášení, které programy produkují. Proto se často chybový výstup přesměrovává do speciálního souboru <code>/dev/null</code>, který funguje zhruba jako bezedný odpadkový koš (vše, co se do něj zapíše, se ihned zahodí):
 
 
find /proc -name fd 2> /dev/null
 
grep root: /etc/* 2> /dev/null
 
 
Někdy je naopak potřeba uchovat výstup příkazu včetně chybových hlášení. Všimněte si, že při přesměrování do souboru je spojení standardního výstupu se standardním chybovým výstupem umístěno až za přesměrováním. Pokud by byl zápis proveden obráceně, nebude fungovat.
 
 
grep root: /etc/* > text.txt 2>&1
 
 
Při [[Programování v shellu BASH|programování skriptů]] je někdy vhodné jednoduše přesměrovat standardní výstup příkazu na standardní chybový výstup:
 
 
echo POZOR: nemohu přečíst soubor XY 1>&2
 
 
== Kolona ==
 
 
 
:{| class=wikitable
 
! Konstrukce
 
! Funkce
 
|-
 
| align=center | <code>příkaz1 | příkaz2</code>
 
| Propojení standardního výstupu programu <code>příkaz1</code> do standardního vstupu programu <code>příkaz2</code>
 
|-
 
| align=center | &nbsp;<code>příkaz1&nbsp;2>&1&nbsp;|&nbsp;příkaz2</code>&nbsp;
 
| Nasměrování spojeného standardního výstupu a standardního chybového výstupu programu <code>příkaz1</code> do standardního vstupu programu <code>příkaz2</code>
 
|}
 
 
=== Příklady ===
 
Činnost níže uvedených příkladů zkoumejte tak, že nejprve provedete první příkaz (včetně jeho parametrů až ke znaku roury) a pak postupně přidávejte další. Sledujte, jak se výstup mění a zjistěte proč.
 
 
grep rp /etc/passwd | sort
 
cut -d: -f3 /etc/passwd | sort -n
 
last | cut -d\  -f1 | sort | uniq -c | sort -n
 

Verze z 27. 10. 2009, 07:25

Žolíkové znaky slouží k tomu, aby nebylo nutné uvádět všechny parametry příkazů explicitně, ale bylo možné použít obecné zadání. Lze například pracovat se všemi soubory s příponou txt nebo se všemi, které vyhovují jiným podmínkám (začínají na určité znaky, obsahují slovo atd.).

Konstrukce Funkce
* Jakékoliv znaky (i žádný znak)
? Jakýkoliv právě jeden znak
[abc] Jeden z uvedených znaků (zde a, b nebo c)
[^abc] Žádný z uvedených znaků (cokoliv kromě a, b nebo c)
 {slovo1,slovo2}  Jedno z uvedených slov (zde slovo1 nebo slovo2)

Příklady

ls /bin/*sh           # vypíše z adresáře /bin vše, co končí na sh 
ls /bin/[bcd]*        # vypíše z adresáře /bin vše začínající na b, c nebo d
ls -d /etc/[ab]*      # vypíše z adresáře /etc vše začínající na a nebo b
ls /bin/[^abc]*       # vypíše z adresáře /bin vše, co nezačíná na a, b nebo c
ls *{txt,doc}         # vypíše v aktuálním adresáři vše končící na .txt nebo .doc
ls /{bin,sbin}/c*     # vypíše z adresářů /bin a /sbin vše, co začíná na c
ls /{,s}bin/c*        # vypíše z adresářů /bin a /sbin vše, co začíná na c