while: Unterschied zwischen den Versionen

Aus Mikiwiki
Zur Navigation springen Zur Suche springen
 
(12 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 26: Zeile 26:
  2
  2
  3
  3
20 Sekunden warten und herunterzählen am Bildschirm.
$ <b>x=20 && while [ $x -gt 0 ]; do let x-=1 && sleep 1; echo -n "$x "; done && echo ""</b>
19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0


----
----
$ <b>while true; do echo $(date '+%H:%M'); sleep 60; done</b>


  $ <b>while true</b>
  $ <b>while true</b>
Zeile 56: Zeile 63:
=== Countdown ===
=== Countdown ===


  function countdown
  function countdown()
  {
  {
  local OLD_IFS="${IFS}"
   IFS=:
   IFS=":"
   set -- $*
   local ARR=( $1 )
   secs=$(( ${1#0} * 3600 + ${2#0} * 60 + ${3#0} ))
   local SECONDS=$(( (ARR[0] * 60 * 60) + (ARR[1] * 60) + ARR[2]  ))
   PREFIX="$4" ; [ -n "${PREFIX}" ] && PREFIX="${PREFIX}: "
   local START=$(date +%s)
   while [ $secs -gt 0 ]
  local END=$((START + SECONDS))
  do
  local CUR=$START
     sleep 1 &
     printf "\r%s%02d:%02d:%02d" "${PREFIX}" \
   while <nowiki>[[ $CUR -lt $END ]]</nowiki>
      $((secs/3600)) $(( (secs/60)%60)) $((secs%60))
    do
     secs=$(( $secs - 1 ))
     CUR=$(date +%s)
     wait
    LEFT=$((END-CUR))
  done
     printf "\r%02d:%02d:%02d" \
   printf "\r%s%02d:%02d:%02d" "${PREFIX}"
            $((LEFT/3600)) $(( (LEFT/60)%60)) $((LEFT%60))
   echo
     sleep 1
     done
   IFS="${OLD_IFS}"
   echo "        "
  }
  }
   
   
  countdown "00:00:30"
  countdown "00:00:03" "Auf geht's"
<!--
Countdown im Terminal:
 
clear && for i in $(seq -10 0); do clear && tput cup 1 0 && echo "$i"; sleep 1; done
-->





Aktuelle Version vom 2. Dezember 2015, 09:05 Uhr

Der Shell-Befehl while bewirkt eine Schleife, welche solange wiederholt wird wie eine anfangs stehende Bedingung erfolgreich ist (also Exit-Status 0 liefert). Die Abwicklung der Schleife wird dabei vom Exit-Status eines Befehls gesteuert.

Syntax

Die Shell führt Befehlsliste2 nur dann aus, wenn der letzte Befehl aus Befehlsliste1 den Exit-Status 0 geliefert hat. Nach jedem Schleifendurchlauf führt die Shell Befehlsliste1 erneut aus.

while Befehlsliste1
  do
    Befehlsliste2
  done

Verwendung

Alle 30 Sekunden soll ein "x" auf den Bildschirm geschrieben werden. Das kann nützlich sein, um eine SSH-Verbindung auf einem zweiten Bildschirm am Leben zu erhalten, wenn etwa auf dem Router "dialer idle-timeout 90" eingestellt ist.

$ while true; do echo -n "x"; sleep 30; done

...

$ x=0
$ while test $x -lt 3
> do
> let x+=1
> echo ${x}
> done
1
2
3

20 Sekunden warten und herunterzählen am Bildschirm.

$ x=20 && while [ $x -gt 0 ]; do let x-=1 && sleep 1; echo -n "$x "; done && echo ""
19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 

$ while true; do echo $(date '+%H:%M'); sleep 60; done
$ while true
> do
> banner $(date '+%H:%M')
> sleep 60
> done

Mit der folgenden Schleife können beliebig viele Parameter ausgewertet werden. Durch "( $@ )" wird dabei die Parameterkette an den Leerzeichen in einzelne Abschnitte aufgespalten un nacheinander in ein eindimensionales Array gespeichert.

#!/bin/bash
declare -i i=0
array=( $@ )
while [ $i -le $# ]; do
  echo "Inhalt von array[$i]: ${array[$i]}"
  i=$i+1
done

$ ./while.sh 1 2 "3 4 5"
Inhalt von array[0]: 1
Inhalt von array[1]: 2
Inhalt von array[2]: 3
Inhalt von array[3]: 4

Auf den ersten Eintrag könnte auch mit "echo $array[0]" zugegriffen werden.

Countdown

function countdown()
{
  IFS=:
  set -- $*
  secs=$(( ${1#0} * 3600 + ${2#0} * 60 + ${3#0} ))
  PREFIX="$4" ; [ -n "${PREFIX}" ] && PREFIX="${PREFIX}: "
  while [ $secs -gt 0 ]
  do
    sleep 1 &
    printf "\r%s%02d:%02d:%02d" "${PREFIX}" \
      $((secs/3600)) $(( (secs/60)%60)) $((secs%60))
    secs=$(( $secs - 1 ))
    wait
  done
  printf "\r%s%02d:%02d:%02d" "${PREFIX}"
  echo
}

countdown "00:00:03" "Auf geht's"