Homebrew (Wikipedie), správce balíčků pro macOS a od verze 2.0.0 také pro Linux, byl vydán ve verzi 4.5.0. Na stránce Homebrew Formulae lze procházet seznamem balíčků. K dispozici jsou také různé statistiky.
Byl vydán Mozilla Firefox 138.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 138 je již k dispozici také na Flathubu a Snapcraftu.
Šestnáctý ročník ne-konference jOpenSpace se koná 3. – 5. října 2025 v Hotelu Antoň v Telči. Pro účast je potřeba vyplnit registrační formulář. Ne-konference neznamená, že se organizátorům nechce připravovat program, ale naopak dává prostor všem pozvaným, aby si program sami složili z toho nejzajímavějšího, čím se v poslední době zabývají nebo co je oslovilo. Obsah, který vytvářejí všichni účastníci, se skládá z desetiminutových
… více »Richard Stallman přednáší ve středu 7. května od 16:30 na Technické univerzitě v Liberci o vlivu technologií na svobodu. Přednáška je určená jak odborné tak laické veřejnosti.
Jean-Baptiste Mardelle se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 25.04.0 editoru videa Kdenlive (Wikipedie). Ke stažení také na Flathubu.
TmuxAI (GitHub) je AI asistent pro práci v terminálu. Vyžaduje účet na OpenRouter.
Byla vydána nová verze R14.1.4 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5, Wikipedie). Přehled novinek i s náhledy v poznámkách k vydání. Podrobný přehled v Changelogu.
Bylo vydáno OpenBSD 7.7. Opět bez písničky.
V Tiraně proběhl letošní Linux App Summit (LAS) (Mastodon). Zatím nesestříhané videozáznamy přednášek jsou k dispozici na YouTube.
printf
sloužící k formátování a výpisu textu, dále wc
, který umí spočítat počet řádků, slov, znaků či bajtů v textu, potom nl
, který umí očíslovat řádky, a nakonec tee
, který umí výstup jiného programu ukládat do souboru a zároveň vypisovat na standardní výstup.Příkaz printf
je podobný stejnojmenné standardní funkci jazyka C a slouží k formátování a výpisu textu. Název je zkratka anglického výrazu print formatted, tedy tisknout formátovaně.
Lze ho používat jako alternativu dříve zmiňovaného příkazu echo, ovšem zde se sluší zmínit diskuzní vlákno, které pod článkem vzniklo, a také citovat SUS standard, ze kterého pro tento článek čerpám. Přímo standard doporučuje se používání echo
vyhnout a v nových skriptech používat printf
, protože je přenositelnější (a lze pomocí něj snadněji vypsat „-n“ :-)).
Jak se printf
používá? Stejně jako v C, ovšem s tím rozdílem, že Bash nerozlišuje datové typy, takže i čísla lze vypsat jako řetězce.
$ printf "Váš domovský adresář je %s\n" $HOME Váš domovský adresář je /home/dave $ printf "%f %f %.1f\n" 123 124,45 12 123,000000 124,450000 12,0
Nerad bych diskriminoval uživatele C netknuté, proto použití trochu rozeberu: Jako první argument se zadává řetězec s formátováním, obsahující fixní řetězce (např. „ahoj“), escapovací sekvence (např. „\n
“ pro nový řádek, „\\
“ pro zpětné lomítko či „\t
“ pro horizontální odsazení – tab), a také řetězce, které budou nahrazeny za proměnné („%s
“ za řetězec, „%d
“ za celé číslo, „%f
“ za desetinné číslo, „%c
“ za 1 znak, atp.). Další argumenty jsou řetězce, které budou dosazeny za proměnné umístěné v prvním argumentu.
$ printf "První řetězec: %s, druhý řetězec: %s, atd.\n" str1 str2 První řetězec: str1, druhý řetězec: str2, atd. $ n=42,12 $ printf "Formátujeme číslo:\n\tCelé číslo: %.0f\n\t3 desetinná místa: %.3f\n" $n $n
Dávejte si pozor na oddělovač desetinného místa. Pokud váš systém používá českou locale (snadno zjistíte příkazem locale
), potom je oddělovač čárka, zatímco ve výchozím locale („C“) je to tečka a v jiných to může být zase jiný znak, takže na to nespoléhejte. A chcete-li napsat znak „%“ tak, jak je, pište „%%“.
$ printf "%%c vypíše pouze 1 znak ze zadaného řetězce: %c%c%c%c%c\n" z n "" a ky %c vypíše pouze 1 znak ze zadaného řetězce: znak
Program wc
slouží ke zjištění počtu řádků, slov, znaků či bajtů v daném textu. Název je zkratkou word count, česky počet slov.
Text lze programu zadat na standardní vstup
# vypíše počet řádků, které by příkaz „ps ax“ jinak vypsal na výstup $ ps ax | wc -l 195 # vypíše počet bajtů textu v /proc/cpuinfo $ wc -c < /proc/cpuinfo 3240
nebo je možné dodat názvy souborů, které se mají analyzovat. Použijete-li wc
takto, vypíše za požadovaná čísla ještě název souboru.
# vypíše počet řádků, slov a bajtů textu v daném souboru $ wc qconf.patch 46 115 921 qconf.patch
Z komentářů u jednotlivých ukázek je zřejmé, že wc
bez argumentů vypíše počet řádků, slov a bajtů (v tomto pořadí) a že lze zajistit i výpis jen požadovaných počtů: Přepínač -l
(v GNU též --lines
) zajistí výpis počtu řádků, -w
(v GNU i --words
) počet slov, -c
(v GNU také --bytes
) počet bajtů a ještě jsem nezmínil přepínač -m
(v GNU i --chars
), který slouží pro výpis počtu znaků.
Program nl
slouží k očíslování řádků. Název je zkratkou number lines, česky očísluj řádky.
Základní použití je zjevné:
$ printf "raz\ndva\ntři\n" > txt $ nl txt 1 raz 2 dva 3 tři
Stejného efektu lze docílit pomocí cat -n
:
$ cat -n txt
S využitím přepínačů lze ovšem docílit i komplexnějšího číslování. Přepínačem -v
lze určit, jakým číslem číslování začne (výchozí je 1, programátoři si mohou nastavit 0). Přepínačem -i
lze ovlivnit, o kolik bude číslo růst s každým novým řádkem (výchozí hodnota je 1).
$ nl -v 0 -i 2 txt 0 raz 2 dva 4 tři
Pomocí přepínače -b
lze určit, které řádky budou číslovány. S argumentem „a“ budou očíslovány všechny řádky, s „t“ pouze neprázdné řádky, s „n“ žádné řádky a s „pregex“ budou očíslovány pouze řádky odpovídající základnímu regulárnímu výrazu regex:
# očísluje pouze řádky, které začínají řetězcem „int“ grep "int" zdrojak.C | nl -b p^int
Přepínač -w
umožňuje zadat počet znaků použitých pro číslo řádku. Výchozí počet je 6. Přepínač -s
umožňuje změnit oddělovač čísla řádku od samotného textového obsahu řádku. Výchozí oddělovač je tab.
$ nl -w 2 -s ": " txt 1: raz 2: dva 3: tři
tee
je program, který umí data, jež jsou mu předána na standardní vstup, ukládat do souboru a zároveň je vypisovat na standardní výstup. Název vychází z toho, jak angličané vyslovují samotné písmeno „T“.
Dovolil jsem si pro ilustraci vypůjčit (GPL) obrázek z wikipedie a lokalizovat jej, protože velmi pěkně vystihuje to, co tee
dělá (a proč se tak jmenuje):
Představte si, že chcete spustit upovídaný program a přejete si jeho std. výstup ukládat do souboru, a zároveň si jej číst, hned jak je vypisován.
# takto docílíte pouze první část požadavku (std. výstup je ukládán do souboru) # na výstupu uvidíte jen stderr, čili std. chybový výstup $ ls -l /usr/bin > soubor.txt # řešení pomocí tee $ ls -l /usr/bin | tee soubor.txt
Je důležité si uvědomit, že když tee
umístíte za rouru, jako jsem to udělal v předchozí ukázce, tak se na std. vstup dostane pouze to, co program před rourou vypisoval na std. výstup, ale už ne to, co vypisoval na chybový výstup (stderr). Pokud chcete ukládat obojí (a mít tak v souboru uložený kompletní výstup programu tak, jak jej vidíte na terminálu), potom je třeba provést patřičné přesměrování výstupu programu.
$ make 2>&1 | tee kompletni_vystup.txt ../dalsi_kopie_vystupu.txt
Nakonec zmíním ještě dostupné přepínače. Přepínač -a
(v GNU též --append
) zajistí, aby se daný soubor, pokud již existuje, nepřepsal, ale aby se místo toho výstup připojil na jeho konec. Přepínač -i
(v GNU též --ignore-interrupts
) zajistí ignorování signálu SIGINT, který se příkazu pošle například stisknete-li Ctrl+C při jeho provádění.
Nástroje: Tisk bez diskuse
Tiskni
Sdílej:
The tee utility shall not buffer output.
Docela mne deprimuje, proč bych měl zcela základní funkcionalitu shellu nahrazovat perlem.Protože shell má jen omezené možnosti využití. Od jisté hranice je lepší použít nějaký silnější nástroj. Tvorba pseudo terminálu je patrně za touto hranicí.
Perl neumím a co teď?Zkuste se to naučit, třeba se Vám zalíbí.
Mám se ptát v poradně abclinuxu?Určitě.
Jinak dotazů na tenhle problém jsem na googlu našel dva tisíce.Pak je to asi častý problém. Čím častější, tím déle se řeší :)
Nechápu, proč si člověk nemůže nastavit buffering mode (block, line, unbuffered) přímo v bashi.Protože to nemá nic společného s bashem, ale se způsobem jak funguje OS. BTW, podle toho komentáře níže byste možná mohl uspět také s tím příkazem stdbuf.
Protože si myslí, že tee místo fwrite(3) použije write(2), který žádný buffer sám o sobě nezavádí. To ovšem vůbec nemusí být pravda, klidně může použít fwrite(3), ale bufferování musí podle POSIXu vypnout.
Takže bych se osobně přikláněl k verzi, že konkrétní implementace tee byla prostě rozbitá. Jestli na stdout zapisuje tee nebo jiný proces, je totiž z hlediska terminálu jedno.
$ printf "Hello world!" bash: !": event not found $ printf 'Hello world!' Hello world!Jakym zpusobem ale vyresit nasledujici? Expanze promenych vs. specialni znaky, tzn. chci zobrazit hodnotu prom. HOME ale nechci aby mi bash hlasil chybu 'event not found'.
$ printf "$HOME !" bash: !": event not found vs. $ printf '$HOME !' $HOME !Asi takhle:
$ printf '%s !' $HOMENebude teda lepsi davat formatovaci retezec do jednoduchych uvozovek (v pripade BASHe)?
Raději:$ printf '%s !' $HOME
$ printf '%s !' "$HOME"
Nebude teda lepsi davat formatovaci retezec do jednoduchych uvozovek (v pripade BASHe)?Určitě. Bonusová otázka: co je špatně u následujícího?
$ printf "$HOME"'!'