Выбрать главу

exit $E_BADARGS

fi

for filename in *.$1

# Цикл прохода по списку имен файлов, имеющих расширение равное первому аргументу.

do

mv $filename ${filename%$1}$2

# Удалить первое расширение и добавить второе,

done

exit 0

Подстановка значений переменных / Замена подстроки

Эти конструкции перекочевали в Bash из ksh.

${var:pos}

Подстанавливается значение переменной var, начиная с позиции pos.

${var:pos:len}

Подстанавливается значение переменной var, начиная с позиции pos, не более len символов. См. Пример A-16.

${var/Pattern/Replacement}

Первое совпадение с шаблоном Pattern, в переменной var замещается подстрокой Replacement.

Если подстрока Replacement отсутствует, то найденное совпадение будет удалено.

${var//Pattern/Replacement}

Глобальная замена. Все найденные совпадения с шаблоном Pattern, в переменной var, будут замещены подстрокой Replacement.

Как и в первом случае, если подстрока Replacement отсутствует, то все найденные совпадения будут удалены.

Пример 9-18. Поиск по шаблону при анализе произвольных строк

#!/bin/bash

var1=abcd-1234-defg

echo "var1 = $var1"

t=${var1#*-*}

echo "var1 (все, от начала строки по первый символ \"-\", включительно, удаляется) = $t"

# t=${var1#*-} то же самое,

#+ поскольку оператор # ищет кратчайшее совпадение,

#+ а * соответствует любым предшествующим символам, включая пустую строку.

# (Спасибо S. C. за разъяснения.)

t=${var1##*-*}

echo "Если var1 содержит \"-\", то возвращается пустая строка... var1 = $t"

t=${var1%*-*}

echo "var1 (все, начиная с последнего \"-\" удаляется) = $t"

echo

# -------------------------------------------

path_name=/home/bozo/ideas/thoughts.for.today

# -------------------------------------------

echo "path_name = $path_name"

t=${path_name##/*/}

echo "Из path_name удален путь к файлу = $t"

# В данном случае, тот эе эффект можно получить так: t=`basename $path_name`

# t=${path_name%/}; t=${t##*/} более общее решение,

#+ но имеет некоторые ограничения.

# Если $path_name заканчивается символом перевода строки, то `basename $path_name` не будет работать,

#+ но для данного случая вполне применимо.

# (Спасибо S.C.)

t=${path_name%/*.*}

# Тот же эффект дает t=`dirname $path_name`

echo "Из path_name удалено имя файла = $t"

# Этот вариант будет терпеть неудачу в случаях: "../", "/foo////", # "foo/", "/".

# Удаление имени файла, особенно когда его нет,

#+ использование dirname имеет свои особенности.

# (Спасибо S.C.)

echo

t=${path_name:11}

echo "Из $path_name удалены первые 11 символов = $t"

t=${path_name:11:5}

echo "Из $path_name удалены первые 11 символов, выводится 5 символов = $t"

echo

t=${path_name/bozo/clown}

echo "В $path_name подстрока \"bozo\" заменена на \"clown\" = $t"

t=${path_name/today/}

echo "В $path_name подстрока \"today\" удалена = $t"

t=${path_name//o/O}

echo "В $path_name все символы \"o\" переведены в верхний регистр, = $t"

t=${path_name//o/}

echo "Из $path_name удалены все символы \"o\" = $t"

exit 0

${var/#Pattern/Replacement}

Если в переменной var найдено совпадение с Pattern, причем совпадающая подстрока расположена в начале строки (префикс), то оно заменяется на Replacement. Поиск ведется с начала строки

${var/%Pattern/Replacement}

Если в переменной var найдено совпадение с Pattern, причем совпадающая подстрока расположена в конце строки (суффикс), то оно заменяется на Replacement. Поиск ведется с конца строки

Пример 9-19. Поиск префиксов и суффиксов с заменой по шаблону

#!/bin/bash

# Поиск с заменой по шаблону.

v0=abc1234zip1234abc # Начальное значение переменной.

echo "v0 = $v0" # abc1234zip1234abc

echo

# Поиск совпадения с начала строки.

v1=${v0/#abc/ABCDEF} # abc1234zip1234abc

# |-|

echo "v1 = $v1" # ABCDE1234zip1234abc