Bash
getopts: inteligentna analiza parametrów pozycyjnych
Szukaj…
Składnia
- getopts optstring name [args]
Parametry
Parametr | Szczegół |
---|---|
optstring | Znaki opcji do rozpoznania |
Nazwa | Następnie podaj nazwę, w której przechowywana jest parsowana opcja |
Uwagi
Opcje
optstring
: Znaki opcji do rozpoznaniaJeśli po znaku następuje dwukropek, opcja powinna zawierać argument, który powinien być od niej oddzielony spacją. Dwukropek (
:
) (i znak zapytania?
) Nie mogą być stosowane jako znaki opcji.
Za każdym razem, gdy jest wywoływana, getopts
umieszcza następną opcję w nazwie zmiennej powłoki, inicjując nazwę, jeśli nie istnieje, oraz indeks następnego argumentu, który ma zostać przetworzony, w zmienną OPTIND
. OPTIND
jest inicjowany na 1
każdym razem, gdy wywoływana jest powłoka lub skrypt powłoki.
Gdy opcja wymaga argumentu, getopts
umieszcza ten argument w zmiennej OPTARG
. Powłoka nie resetuje automatycznie OPTIND
; musi zostać ręcznie zresetowany między wieloma wywołaniami getopts
w ramach tego samego wywołania powłoki, jeśli ma być użyty nowy zestaw parametrów.
Po napotkaniu końca opcji getopts
kończy działanie z wartością zwracaną większą niż zero.
OPTIND
jest ustawiony na indeks pierwszego argumentu nie będącego opcją, a nazwa jest ustawiona na ?
. getopts
zwykle analizuje parametry pozycyjne, ale jeśli podano więcej argumentów w args
, getopts
parsuje je zamiast tego.
getopts
może zgłaszać błędy na dwa sposoby. Jeśli pierwszy znak optstring
jest dwukropek ( :
), stosowany jest cichy raportowanie błędów. W normalnej pracy komunikaty diagnostyczne są drukowane, gdy napotkane zostaną nieprawidłowe opcje lub brakujące argumenty opcji.
Jeśli zmienna OPTERR
jest ustawiona na 0
, żadne komunikaty o błędach nie będą wyświetlane, nawet jeśli pierwszym znakiem optstring
nie jest dwukropek.
Jeśli pojawi się nieprawidłowa opcja, getopts
miejsca ?
na name
i, jeśli nie jest cichy, drukuje komunikat o błędzie i resetuje OPTARG
. Jeśli getopts
milczy, znaleziony znak opcji jest umieszczany w OPTARG
i nie jest drukowany komunikat diagnostyczny.
Jeśli wymagany argument nie zostanie znaleziony, a getopts
nie milczy, w name
umieszczany jest znak zapytania ( ?
), OPTARG
jest rozbrojony i drukowany jest komunikat diagnostyczny. Jeżeli getopts
milczy, a następnie dwukropek ( :
) jest umieszczony w imieniu i OPTARG
jest ustawiony na znak opcji.
pingnmap
#!/bin/bash
# Script name : pingnmap
# Scenario : The systems admin in company X is tired of the monotonous job
# of pinging and nmapping, so he decided to simplify the job using a script.
# The tasks he wish to achieve is
# 1. Ping - with a max count of 5 -the given IP address/domain. AND/OR
# 2. Check if a particular port is open with a given IP address/domain.
# And getopts is for her rescue.
# A brief overview of the options
# n : meant for nmap
# t : meant for ping
# i : The option to enter the IP address
# p : The option to enter the port
# v : The option to get the script version
while getopts ':nti:p:v' opt
#putting : in the beginnnig suppresses the errors for invalid options
do
case "$opt" in
'i')ip="${OPTARG}"
;;
'p')port="${OPTARG}"
;;
'n')nmap_yes=1;
;;
't')ping_yes=1;
;;
'v')echo "pingnmap version 1.0.0"
;;
*) echo "Invalid option $opt"
echo "Usage : "
echo "pingmap -[n|t[i|p]|v]"
;;
esac
done
if [ ! -z "$nmap_yes" ] && [ "$nmap_yes" -eq "1" ]
then
if [ ! -z "$ip" ] && [ ! -z "$port" ]
then
nmap -p "$port" "$ip"
fi
fi
if [ ! -z "$ping_yes" ] && [ "$ping_yes" -eq "1" ]
then
if [ ! -z "$ip" ]
then
ping -c 5 "$ip"
fi
fi
shift $(( OPTIND - 1 )) # Processing additional arguments
if [ ! -z "$@" ]
then
echo "Bogus arguments at the end : $@"
fi
Wynik
$ ./pingnmap -nt -i google.com -p 80
Starting Nmap 6.40 ( http://nmap.org ) at 2016-07-23 14:31 IST
Nmap scan report for google.com (216.58.197.78)
Host is up (0.034s latency).
rDNS record for 216.58.197.78: maa03s21-in-f14.1e100.net
PORT STATE SERVICE
80/tcp open http
Nmap done: 1 IP address (1 host up) scanned in 0.22 seconds
PING google.com (216.58.197.78) 56(84) bytes of data.
64 bytes from maa03s21-in-f14.1e100.net (216.58.197.78): icmp_seq=1 ttl=57 time=29.3 ms
64 bytes from maa03s21-in-f14.1e100.net (216.58.197.78): icmp_seq=2 ttl=57 time=30.9 ms
64 bytes from maa03s21-in-f14.1e100.net (216.58.197.78): icmp_seq=3 ttl=57 time=34.7 ms
64 bytes from maa03s21-in-f14.1e100.net (216.58.197.78): icmp_seq=4 ttl=57 time=39.6 ms
64 bytes from maa03s21-in-f14.1e100.net (216.58.197.78): icmp_seq=5 ttl=57 time=32.7 ms
--- google.com ping statistics ---
5 packets transmitted, 5 received, 0% packet loss, time 4007ms
rtt min/avg/max/mdev = 29.342/33.481/39.631/3.576 ms
$ ./pingnmap -v
pingnmap version 1.0.0
$ ./pingnmap -h
Invalid option ?
Usage :
pingmap -[n|t[i|p]|v]
$ ./pingnmap -v
pingnmap version 1.0.0
$ ./pingnmap -h
Invalid option ?
Usage :
pingmap -[n|t[i|p]|v]