6 999
contributi
S3v (discussione | contributi) |
S3v (discussione | contributi) |
||
(24 versioni intermedie di 2 utenti non mostrate) | |||
Riga 1: | Riga 1: | ||
{{Versioni compatibili}} | {{Versioni compatibili}} | ||
==Intro== | ==Intro== | ||
'''GNU Bash''' è la shell *nix probabilmente più ricca di funzionalità sia per l'uso interattivo che per lo scripting. Spesso però molte funzioni sono poco note. | '''GNU Bash''' è la shell *nix probabilmente più ricca di funzionalità sia per l'uso interattivo che per lo scripting. Spesso però molte funzioni sono poco note.<br> | ||
Questa pagina ha lo scopo di raccogliere il più ampio numero di "trucchi" più o meno noti riguardanti Bash, senza avere peraltro la pretesa di coprire tutte le funzionalità. | |||
Si noti che per gli script di sistema è consigliabile limitarsi alle sole istruzioni della shell '''sh''' secondo lo standard ''POSIX'', supportate per esempio da <code>'''dash'''</code>, più leggera ma anche meno potente e poco indicata come shell interattiva. | |||
Riga 21: | Riga 22: | ||
* È possibile salvare un percorso con <code>'''pushd'''</code> e richiamarlo con <code>'''popd'''</code>. In realtà questi comandi (come il nome può fare intuire) implementano una coda FIFO (First In First Out) nella quale è possibile memorizzare un numero illimitato di percorsi per poi richiamarli dall'ultimo inserito in poi. Usare questi comandi è semplicissimo: basta usare <code>[[Navigazione_veloce_tra_directory:_pushd,_popd_e_dirs#Pushd|pushd]]</code> al posto di <code>'''cd'''</code> (in tal modo si memorizzano i percorsi via via visitati) e poi digitare <code>[[Navigazione_veloce_tra_directory:_pushd,_popd_e_dirs#Popd|popd]]</code> una o più volte per tornare indietro. | * È possibile salvare un percorso con <code>'''pushd'''</code> e richiamarlo con <code>'''popd'''</code>. In realtà questi comandi (come il nome può fare intuire) implementano una coda FIFO (First In First Out) nella quale è possibile memorizzare un numero illimitato di percorsi per poi richiamarli dall'ultimo inserito in poi. Usare questi comandi è semplicissimo: basta usare <code>[[Navigazione_veloce_tra_directory:_pushd,_popd_e_dirs#Pushd|pushd]]</code> al posto di <code>'''cd'''</code> (in tal modo si memorizzano i percorsi via via visitati) e poi digitare <code>[[Navigazione_veloce_tra_directory:_pushd,_popd_e_dirs#Popd|popd]]</code> una o più volte per tornare indietro. | ||
:A tal proposito vedere anche: [[Navigazione veloce tra directory: pushd, popd e dirs]] | :A tal proposito vedere anche: [[Navigazione veloce tra directory: pushd, popd e dirs]] | ||
===Editing della linea di comando=== | ===Editing della linea di comando=== | ||
Riga 41: | Riga 30: | ||
Alcuni tasti di scelta rapida per l'editing da linea di comando: | Alcuni tasti di scelta rapida per l'editing da linea di comando: | ||
{| class="wikitable" style="width: | {| class="wikitable" style="width:80%" | ||
| align="center" | '''Descrizione''' | | align="center"; width="30%" | '''Descrizione''' | ||
| align="center" | '''Vim-like(CommandMode)''' | | align="center"; width="30%"| '''Vim-like(CommandMode)''' | ||
| align="center" | '''Emacs-like''' | | align="center"; width="40%" | '''Emacs-like''' | ||
|- | |- | ||
| Vai all'inizio delle linea || 0 (zero) || CTRL+a | | Vai all'inizio delle linea || 0 (zero) || CTRL+a | ||
Riga 71: | Riga 60: | ||
{{Box|Nota per la modalità Command Mode|Si entra in Command Mode premendo ESC. Per tornare in modalità inserimento è necessario pigiare il tasto i.}} | {{Box|Nota per la modalità Command Mode|Si entra in Command Mode premendo ESC. Per tornare in modalità inserimento è necessario pigiare il tasto i.}} | ||
{{Box|Nota sul tasto META|Il tasto Meta può essere usato premendo <code>ALT</code> e ''contemporaneamente'' il carattere del comando che interessa, oppure premendo <code>ESC</code> e ''successivamente'' il tasto del comando che interessa. In quest'ultimo modo non è necessario premere due tasti contemporaneamente. Questa è una regola generica per gli shortcut di bash che usano il tasto Meta.}} | {{Box|Nota sul tasto META|Il tasto Meta può essere usato premendo <code>ALT</code> e ''contemporaneamente'' il carattere del comando che interessa, oppure premendo <code>ESC</code> e ''successivamente'' il tasto del comando che interessa. In quest'ultimo modo non è necessario premere due tasti contemporaneamente. Questa è una regola generica per gli shortcut di bash che usano il tasto Meta.}} | ||
===Riutilizzo degli argomenti=== | |||
Bash memorizza l'ultimo argomento del comando precedente in una speciale variabile chiamata <code>$_</code>. È possibile fare riferimento all'ultimo argomento dell'ultimo comando usando direttamente <code>$_</code> ma in modalità Emacs la via di gran lunga più veloce e comoda è usare <code>ESC</code> . | |||
Ecco un esempio stupido, creare una directory ed entrarvi: | |||
$ mkdir /usr/local/nuovo-programma | |||
$ cd ESC. | |||
Altro esempio forse un po' più utile, creare velocemente uno script: | |||
$ :> /usr/local/bin/nomescript | |||
$ chmod +x ESC. | |||
$ gvim ESC. | |||
In alternativa si possono usare le espansioni dello storico, presenti solo quando la shell è avviata in modalità interattiva. | |||
===Uso avanzato dello storico=== | ===Uso avanzato dello storico=== | ||
Riga 146: | Riga 149: | ||
</pre> | </pre> | ||
== | ==Comandi avanzati== | ||
Alcuni comandi, anche se utilizzati più spesso negli script, hanno una loro utilità anche nella shell interattiva. Per esempio con le concatenazioni per eseguire più comandi in successione, senza attendere la terminazione di ognuno, oppure con le redirezioni per redirigere l'output su un file, per poterlo leggere con un editor di testo o salvarlo. | |||
===Concatenazioni=== | |||
; <code>&&</code> : operatore logico AND, il secondo comando verrà eseguito solo se il primo avrà esito positivo | ; <code>&&</code> : operatore logico AND, il secondo comando verrà eseguito solo se il primo avrà esito positivo | ||
; <code>;</code> : separatore di comandi, il secondo comando verrà eseguito in ogni caso | ; <code>;</code> : separatore di comandi, il secondo comando verrà eseguito in ogni caso (in uno script è equivalente a un "a capo" e questa è la concatenazione di default) | ||
$ cd ... && echo done | $ cd ... && echo done | ||
Riga 247: | Riga 165: | ||
$ xterm ; xterm -rv | $ xterm ; xterm -rv | ||
$ xterm & xterm -rv | $ xterm & xterm -rv | ||
; <code>||</code> : operatore logico OR, restituisce esito positivo se almeno una delle condizioni di verifica valutate è vera | ; <code>||</code> : operatore logico OR, restituisce esito positivo se almeno una delle condizioni di verifica valutate è vera | ||
Riga 264: | Riga 178: | ||
* [http://www.tldp.org/LDP/abs/html/special-chars.html Advanced Bash-Scripting Guide: Special Characters] | * [http://www.tldp.org/LDP/abs/html/special-chars.html Advanced Bash-Scripting Guide: Special Characters] | ||
===Redirezioni=== | |||
Pipe, che passa l'output del comando che la precede come input del comando che la segue | |||
$ ls -A1 | less | |||
Dirige output di comando su file: | Dirige output di comando su file: | ||
$ man xterm > xterm.txt | $ man xterm > xterm.txt | ||
Riga 280: | Riga 196: | ||
$ :> xterm.txt | $ :> xterm.txt | ||
=== | === Cambiare l'estensione ai file === | ||
Rinomina tutti i file <code>*.txt</code> della directory corrente in <code>*.log</code>: | |||
$ for f in ./*.txt; do if [ -e "$f" ]; then mv -- "$f" "${f/%txt/log}"; fi; done | |||
{{Suggerimento | Premettere ./ ad * è sempre consigliabile per impedire che file inizianti con "-" possano essere riconosciuti come opzioni. | |||
Allo stesso scopo l'opzione "--" dopo il comando esterno <code>mv</code> serve per comunicargli che le stringhe che seguono non sono opzioni, nemmeno se iniziassero con il carattere "-". È sempre buona norma utilizzarla come controllo aggiuntivo con comandi che accettano file come argomenti.}} | |||
Un modo alternativo consiste nell'utilizzare il comando "rename": | |||
<pre> | <pre> | ||
$ rename 's/.txt$/.old/' *.txt | |||
</pre> | </pre> | ||
con cui si cambierà l'estensione di tutti i file ".txt" in ".old" . | |||
=== | === Espansioni avanzate === | ||
Molte espansioni che non possono essere racchiuse tra virgolette (non quotabili), ossia quelle di percorso, di tilde e di parentesi, sono molto utili in modalità interattiva. | |||
A titolo di esempio, la tilde <code>~</code> può essere usata per sostituirsi alla propria home, senza scriverla ogni volta per intero; e <code>~utente</code> per riferirsi alla home di un altro utente. Per scrivere il simbolo grafico della tilde con una tastiera con layout italiano basta digitare <code>Ctrl-ì</code>. | |||
$ | Salva alcuni file di configurazione di bash (~/.bashrc, ~/.bash_profile) nell'archivio bash_backup.tgz: | ||
$ tar cvzf bash_backup.tgz ~/.bash{rc,_profile} | |||
Salva tutti i file inizianti con ~/.bash nell'archivio bash_backup.tgz: | |||
$ tar cvzf bash_backup.tgz ~/.bash* | |||
L'espansione di percorso è stata vista in breve, limitatamente al carattere jolly *, ma assieme all'uso di tilde e le espansioni di parentesi, è trattata più nel dettaglio nel capitolo sullo scripting in Bash sulle [[Bash scripting - espansioni non quotabili | espansioni non quotabili]]. | |||
==Il file .bashrc== | ==Il file .bashrc== | ||
Riga 326: | Riga 251: | ||
# seleziona, apri file, incolla, salva: noioso | # seleziona, apri file, incolla, salva: noioso | ||
# quota il tutto e appendi ad un file con echo: già meglio | # quota il tutto e appendi ad un file con echo: già meglio | ||
# <code>'''CTRL-x'''</code> <code>'''CTRL-e'''</code>, si apre il nostro editor di fiducia e salviamo: superbo | # in modalità ''Emacs'' (il default) <code>'''CTRL-x'''</code> <code>'''CTRL-e'''</code>, si apre il nostro editor di fiducia e salviamo: superbo; mentre se si utilizza la modalità ''vi'' è sufficiente premere il tasto '''v''' in modalità comando | ||
===Processo in background=== | ===Processo in background=== | ||
Riga 376: | Riga 301: | ||
$ bind -x '"\C-x\C-r":ls ~' | $ bind -x '"\C-x\C-r":ls ~' | ||
ora con la sequenza <code>'''CTRL-x'''</code> <code>'''CTRL-r'''</code> verrà eseguito il nostro comando. | ora con la sequenza <code>'''CTRL-x'''</code> <code>'''CTRL-r'''</code> verrà eseguito il nostro comando. È possibile anche definire scorciatoie da tastiera a funzioni già supportate da bash ma non ancora assegnate (si veda <code>bind -P</code> per un elenco), e la sintassi è la stessa ma senza l'opzione -x. | ||
Per cancellarla: | Per cancellarla: | ||
$ bind -r "\C-x\C-r" | $ bind -r "\C-x\C-r" | ||
Funziona solo nella shell in cui si crea, a meno che non si inserisca nel file <code>~/.inputrc</code>. | Funziona solo nella shell in cui si crea, a meno che non si inserisca nel file <code>~/.inputrc</code>. Per i dettagli consultare <code>man readline</code>. | ||
===Aiuto veloce=== | |||
La pagina di manuale di bash (si veda <code>man bash</code>) è certamente utilissima ed esaustiva, ma non sempre adatta a un aiuto veloce per rinfrescarsi solo la sintassi di qualche comando. Fortunatamente '''bash''' dispone anche di uno strumento di aiuto integrato tramite la funzione <code>help</code>. | |||
Per la lista di tutti i comandi interni della shell: | |||
$ help | |||
Per informazioni su un comando interno (''shell builtin''), per esempio bind: | |||
$ help bind | |||
Un altro comando utile, per sapere se esiste qualcosa da eseguire con un dato nome, e in caso che cosa verrà eseguito: un alias, una funzione, un comando interno della shell, oppure un eseguibile esterno (e in che percorso). La sintassi: | |||
$ type comando-da-cercare | |||
==Link== | ==Link== | ||
Link ad altre risorse su '''GNU Bash''': | Link ad altre risorse su '''GNU Bash''': | ||
* [http://www.gnu.org/software/bash/manual/bash.html Bash Referece Manual]: manuale ufficiale | * [http://www.gnu.org/software/bash/manual/bash.html Bash Referece Manual]: manuale ufficiale; | ||
* [http://www.tldp.org/LDP/abs/html/ Advanced Bash-Scripting Guide]: | * [[Bash scripting | Bash scripting]]: guida base (a cura di debianizzati) sullo scripting con Bash; | ||
* [http://www.tldp.org/LDP/abs/html/ Advanced Bash-Scripting Guide]: guida avanzata dello scripting in Bash. | |||
{{Autori | {{Autori | ||
Riga 394: | Riga 332: | ||
|Verificata_da= | |Verificata_da= | ||
:[[Utente:S3v|S3v]] | :[[Utente:S3v|S3v]] | ||
:[[Utente:HAL 9000|HAL 9000]] 20:47, 23 lug 2014 (CEST) | |||
|Estesa_da= | |Estesa_da= | ||
:[[Utente:S3v|S3v]] | :[[Utente:S3v|S3v]] | ||
|Numero_revisori= | :[[Utente:HAL 9000|HAL 9000]] | ||
|Numero_revisori=2 | |||
}} | }} | ||
[[Categoria:Bash]] | [[Categoria:Bash]] |
contributi