Я хочу прописать только первый символ в моей строке с помощью bash.
foo="bar";
//uppercase first character
echo $foo;
следует напечатать «Бар»;
Я хочу прописать только первый символ в моей строке с помощью bash.
foo="bar";
//uppercase first character
echo $foo;
следует напечатать «Бар»;
Ответы:
foo="$(tr '[:lower:]' '[:upper:]' <<< ${foo:0:1})${foo:1}"
notQuiteCamelв NotQuiteCamel. Ваш вариант имеет побочный эффект или заставляет оставшиеся в нижнем регистре за счет удвоения количества вложенных оболочек и tr процессов.
bash.
В одну сторону с bash (версия 4+):
foo=bar
echo "${foo^}"
печатает:
Bar
"${foo,}". Чтобы сделать строчными все буквы, используйте "${foo,,}". Для ввода всех букв в верхний регистр используйте "${foo^^}".
${foo~}и ${foo~~}имею такой же эффект как ${foo^}и ${foo^^}. Но я никогда не видел, чтобы эта альтернатива упоминалась где-либо.
bad substitution
Один из способов с sed:
echo "$(echo "$foo" | sed 's/.*/\u&/')"
Печать:
Bar
brew install coreutils gnu-sedи следуйте инструкциям, чтобы использовать команды без префикса g. Что бы это ни стоило, я никогда не хотел запускать OSX-версию этих команд с момента получения версий GNU.
sedв этом случае вам понадобится GNU
sed 's/./\U&/и он будет работать на POSIX sed.
$ foo="bar";
$ foo=`echo ${foo:0:1} | tr '[a-z]' '[A-Z]'`${foo:1}
$ echo $foo
Bar
Вот «родной» способ работы с текстом:
#!/bin/bash
string="abcd"
first=`echo $string|cut -c1|tr [a-z] [A-Z]`
second=`echo $string|cut -c2-`
echo $first$second
tr [:lower:] [:upper:]Это лучший выбор, если он должен работать на языке / языке, включающем буквы, которые не входят в диапазон a-zили A-Z.
Это можно сделать в чистом виде с помощью bash-3.2:
# First, get the first character.
fl=${foo:0:1}
# Safety check: it must be a letter :).
if [[ ${fl} == [a-z] ]]; then
# Now, obtain its octal value using printf (builtin).
ord=$(printf '%o' "'${fl}")
# Fun fact: [a-z] maps onto 0141..0172. [A-Z] is 0101..0132.
# We can use decimal '- 40' to get the expected result!
ord=$(( ord - 40 ))
# Finally, map the new value back to a character.
fl=$(printf '%b' '\'${ord})
fi
echo "${fl}${foo:1}"
foo = $1но я только получаю-bash: foo: command not found
=в заданиях. Это то, что shellcheck.net найдет для вас программно.
=качестве аргумента программы (как он должен знать , если someprogram =работает someprogram, или присвоение переменной с именем someprogram?)
Это тоже работает ...
FooBar=baz
echo ${FooBar^^${FooBar:0:1}}
=> Baz
FooBar=baz
echo ${FooBar^^${FooBar:1:1}}
=> bAz
FooBar=baz
echo ${FooBar^^${FooBar:2:2}}
=> baZ
И так далее.
Источники:
Inroductions / Обучающие программы:
Прописать только первое слово:
foo='one two three'
foo="${foo^}"
echo $foo
О, два, два, три
Чтобы использовать каждое слово в переменной с большой буквы :
foo="one two three"
foo=( $foo ) # without quotes
foo="${foo[@]^}"
echo $foo
О пе Т горе Т HREE
(работает в Bash 4+)
foo='one two three'; foo=$(for i in $foo; do echo -n "${i^} "; done) Более короткое разрешение для каждого слова. foo Сейчас "Один Два Три"
Альтернативное и чистое решение для Linux и OSX, его также можно использовать с переменными bash
python -c "print(\"abc\".capitalize())"
возвращает Abc
Этот работал для меня:
Поиск всех * php файлов в текущем каталоге и замена первого символа каждого имени файла на заглавную букву:
Например: test.php => Test.php
for f in *php ; do mv "$f" "$(\sed 's/.*/\u&/' <<< "$f")" ; done
просто для удовольствия вот вы:
foo="bar";
echo $foo | awk '{$1=toupper(substr($1,0,1))substr($1,2)}1'
# or
echo ${foo^}
# or
echo $foo | head -c 1 | tr [a-z] [A-Z]; echo $foo | tail -c +2
# or
echo ${foo:1} | sed -e 's/^./\B&/'
Не совсем то, что просили, но довольно полезно
declare -u foo #When the variable is assigned a value, all lower-case characters are converted to upper-case.
foo=bar
echo $foo
BAR
И наоборот
declare -l foo #When the variable is assigned a value, all upper-case characters are converted to lower-case.
foo=BAR
echo $foo
bar
first-letter-to-lower () {
str=""
space=" "
for i in $@
do
if [ -z $(echo $i | grep "the\|of\|with" ) ]
then
str=$str"$(echo ${i:0:1} | tr '[A-Z]' '[a-z]')${i:1}$space"
else
str=$str${i}$space
fi
done
echo $str
}
first-letter-to-upper-xc () {
v-first-letter-to-upper | xclip -selection clipboard
}
first-letter-to-upper () {
str=""
space=" "
for i in $@
do
if [ -z $(echo $i | grep "the\|of\|with" ) ]
then
str=$str"$(echo ${i:0:1} | tr '[a-z]' '[A-Z]')${i:1}$space"
else
str=$str${i}$space
fi
done
echo $str
}
first-letter-to-lower-xc () {v-first-letter-to-lower | xclip -selection clipboard}
Что если первый символ не буква (а табуляция, пробел и экранированная двойная кавычка)? Нам лучше проверить это, пока мы не найдем письмо! Так:
S=' \"ó foo bar\"'
N=0
until [[ ${S:$N:1} =~ [[:alpha:]] ]]; do N=$[$N+1]; done
#F=`echo ${S:$N:1} | tr [:lower:] [:upper:]`
#F=`echo ${S:$N:1} | sed -E -e 's/./\u&/'` #other option
F=`echo ${S:$N:1}
F=`echo ${F} #pure Bash solution to "upper"
echo "$F"${S:(($N+1))} #without garbage
echo '='${S:0:(($N))}"$F"${S:(($N+1))}'=' #garbage preserved
Foo bar
= \"Foo bar=
$[...]). Вы используете много бесполезных скобок. Вы предполагаете, что строка состоит из символов латинского алфавита (как насчет акцентированных букв или букв других алфавитов?). У вас есть много работы, чтобы сделать этот фрагмент полезным! (и так как вы используете регулярное выражение, вы можете также использовать регулярное выражение, чтобы найти первую букву вместо цикла).
tr:if [[ $S =~ ^([^[:alpha:]]*)([[:alpha:]].*) ]]; then out=${BASH_REMATCH[1]}${BASH_REMATCH[2]^}; else out=$S; fi; printf '%s\n' "$out"
echo $fooэто пример ситуации, когда парсер ожидает список слов ; так что в вашем echo ${F}, содержимое Fразделено на строки и глобально расширено. Это верно и для echo ${S:$N:1}примера, и для всего остального. Смотрите BashPitfalls # 14 .