Проверьте, соответствуют ли какие-либо параметры скрипта bash строке

Я пытаюсь написать сценарий, в котором я хочу проверить, соответствует ли какой-либо из параметров, переданных сценарию bash, строке. Как у меня настройки сейчас

if [ "" != "-disCopperBld" -a "" != "-disCopperBld" -a "" != "-disCopperBld" -a "" != "-disCopperBld"]

но может быть большое количество параметров, поэтому мне было интересно, есть ли лучший способ сделать это?

спасибо

изменить:
Я попробовал этот кусок кода и вызвал скрипт с опцией-disableVenusBld, но он все равно печатает "Starting build". Я что-то делаю не так? Заранее спасибо!

while [ $# -ne 0 ]
do
    arg=""
    case "$arg" in
        -disableVenusBld)
            disableVenusBld=true
            ;;
        -disableCopperBld)
            disableCopperBld=true
            ;;
        -disableTest)
            disableTest=true
            ;;
        -disableUpdate)
            disableUpdate=true
            ;;
        *)
            nothing="true"
            ;;
    esac
    shift
done

if [ "$disableVenusBld" != true ]; then
    echo "Starting build"
fi
22
задан iman453
07.03.2023 11:45 Количество просмотров материала 2802
Распечатать страницу

4 ответа

похоже, вы выполняете обработку опций в сценарии оболочки. Вот идиома для этого:

#! /bin/sh -

# idiomatic parameter and option handling in sh
while test $# -gt 0
do
    case "" in
        --opt1) echo "option 1"
            ;;
        --opt2) echo "option 2"
            ;;
        --*) echo "bad option "
            ;;
        *) echo "argument "
            ;;
    esac
    shift
done

exit 0

(есть несколько конвенций для отступа ;;, а некоторые оболочки позволяют задавать параметры как (--opt1), чтобы помочь с соответствием скобки, но это основная идея)

50
отвечен Norman Gray 2023-03-08 19:33

это работает для меня. Он делает именно то, что вы больше ничего не просили (без обработки опций). Хорошо это или плохо-упражнение для плаката:)

if [[ "$@" == "your string" ]]
then
    echo "YES"
else
    echo "NO"
fi

обратите внимание, что использование $@, вместо $*, вместе с тем, что он заключен в кавычки, гарантирует гибкость в случае тестовой строки с whitespeces. С $* только "your" или "string" будут подобраны. Бы никакой разницы, если нет пробелов.

посмотреть данное объяснение о различиях в поведении.

16
отвечен Rich Homolka 2023-03-08 21:50

Как насчет поиска (с подстановочными знаками) всего пространства параметров:

if [[ $@ == *'-disableVenusBld'* ]]
then

изменить: Ладно, ладно, это не был популярный ответ. Как насчет этого, он идеально подходит!:

if [[ "${@#-disableVenusBld}" = "$@" ]]
then
    echo "Did not find disableVenusBld"
else
    echo "Found disableVenusBld"
fi

Edit2: Хорошо, хорошо, может быть, это не идеально... Думаю, что это работает, только если -param находится в начале списка, а также будет соответствовать -paramXZY или-paramABC. Я все еще думаю, что оригинальная проблема может быть решена очень хорошо с помощью манипуляции строкой bash, но я не совсем ее взломал... -Мочь ты??

8
отвечен Rich 2023-03-09 00:07
disCopperBld=
for x; do
  if [ "$x" = "-disCopperBld" ]; then disCopperBld=1; break; fi
done
if [ -n "$disCopperBld" ]; then
  ...
fi

Если вам нужно проверить только параметры, начиная с выполните поиск в функции:

## Usage: search_trailing_parameters NEEDLE NUM "$@"
## Search NEEDLE amongst the parameters, skipping  through ${$NUM}.
search_trailing_parameters () {
  needle=
  shift $(( + 2))
  for x; do
    if [ "$x" = "$needle" ]; then return 0; fi
  done
  return 1
}
if search_trailing_parameters -disCopperBld 2 "$@"; then
  ...
fi

но мне интересно, почему вы пытаетесь сделать это в первую очередь, это не общая потребность. Как правило, вы бы процесс опции в порядке, как в ответе Денниса на ваш предыдущий вопрос.

1
отвечен Gilles 2023-03-09 02:24

Постоянная ссылка на данную страницу: [ Скопировать ссылку | Сгенерировать QR-код ]

Ваш ответ

Опубликуйте как Гость или авторизуйтесь

Имя
Вверх