Bash Bashing

Aus ConfigWiki
(Unterschied zwischen Versionen)
Wechseln zu: Navigation, Suche
(Parameter-Expansion)
 
Zeile 100: Zeile 100:
 
==IP-Validierung==
 
==IP-Validierung==
 
<source lang="bash">
 
<source lang="bash">
function valid_ip()
+
function valid_ip()
{
+
{
 
   local  ip=$1
 
   local  ip=$1
 
   local  stat=1
 
   local  stat=1
 
+
 
   # bash 2:
 
   # bash 2:
 
   # if ( echo $ip | egrep '^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$' > /dev/null ) ; then
 
   # if ( echo $ip | egrep '^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$' > /dev/null ) ; then
Zeile 117: Zeile 117:
 
   fi
 
   fi
 
   return $stat
 
   return $stat
}
+
}
 
+
if valid_ip $IP; then
+
if valid_ip $IP; then
 
   echo "IP ist eine IPv4-Adresse"
 
   echo "IP ist eine IPv4-Adresse"
fi
+
fi
 
</source>
 
</source>

Aktuelle Version vom 29. Juni 2013, 09:25 Uhr

Unlesbare Bash-Skripte, unnötige externe Programmaufrufe und überlange Befehlsketten sind vermeidbar. Interessante Beiträge aus der gleichnamigen Beitragsserie des Linux-Magazins und weitere Anregungen folgen hier in Kurzform.

Inhaltsverzeichnis

[Bearbeiten] cut, sed, grep & Co. vermeiden

Quelle: Folge 5, Linux-Magazin 02/10

[Bearbeiten] Parameter-Expansion

Nach dem Schema ${<Variable><Zeichen><Suchmuster>} erledigt die Bash viele Aufgaben selbst, die sonst mit cut, sed, grep oder awk gelöst werden. Als Zeichen # % / ^ , zulässig, die doppelte Angabe schaltet jeweils in den gierigen Modus und ersetzt alles bis zum letzten Vorkommen des Suchmusters.

Zeichen Bedeutung Beispiel
# Löschen von links X="aabcabcc"; ${X#a}; löscht das erste a
## Löschen von links X="aabcabcc"; ${X##a}; löscht alle führenden a (funktioniert in Bash 3.2 nicht, wo ist der Fehler?)
 % Löschen von rechts X="aabcabcc"; ${X%c}; löscht das letzte c
 %% Löschen von rechts X="aabcabcc"; ${X%%c}; löscht alle c am Ende (funktioniert in Bash 3.2 nicht, wo ist der Fehler?)
/ Ersetzen (substitude) X="aabcabcc"; ${X/b/d}; ersetzt 1. b durch d
/ Ersetzen (substitude) X="aabcabcc"; ${X/b}; löscht 1. b
// Ersetzen (substitude) X="aabcabcc"; ${X//b/d}; ersetzt alle b durch d
// Ersetzen (substitude) X="aabcabcc"; ${X//b}; löscht alle b
funktioniert erst ab Bash 4
^ Umwandeln in Großbuchstaben (uppercase) X="aabcabcc"; ${X^a}; wandelt erstes a in A
^^ Umwandeln in Großbuchstaben (uppercase) X="aabcabcc"; ${X^^bc}; wandelt alle bc in BC
^^ Umwandeln in Großbuchstaben (uppercase) X="aabcabcc"; ${X^^}; wandelt alles in Grossbuchstaben
, Umwandeln in Kleinbuchstaben (lowercase) X="AABCABCC"; ${X,A}; wandelt erstes A in a
,, Umwandeln in Kleinbuchstaben (lowercase) X="AABCABCC"; ${X,,BC}; wandelt alle BC in bc
,, Umwandeln in Kleinbuchstaben (lowercase) X="AABCABCC"; ${X,,}; wandelt alles in Kleinbuchstaben
[Bearbeiten] praktische Beispiele

löscht alles bis zum ersten '/' von rechts: <source lang="bash">

VERZEICHNIS="${0%/*}"

</source> ersetzt externen Aufruf: <source lang="bash">

VERZEICHNIS=$(dirname "$0")

</source>

löscht alles bis zum letzten '/' von links: <source lang="bash">

SKRIPTNAME="${0##*/}"

</source> ersetzt externen Aufruf: <source lang="bash">

SKRIPTNAME=$(basename "$0")

</source>

[Bearbeiten] IP-Validierung

<source lang="bash">

function valid_ip()
{
  local  ip=$1
  local  stat=1

  # bash 2:
  # if ( echo $ip | egrep '^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$' > /dev/null ) ; then
  # bash 3:
  if [[ $ip =~ ^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]]; then
      OIFS=$IFS
      IFS='.'
      ip=($ip)
      IFS=$OIFS
      [[ ${ip[0]} -le 255 && ${ip[1]} -le 255 && ${ip[2]} -le 255 && ${ip[3]} -le 255 ]]
      stat=$?
  fi
  return $stat
}

if valid_ip $IP; then
  echo "IP ist eine IPv4-Adresse"
fi

</source>

Meine Werkzeuge