Если у вас есть законная необходимость запускать некоторые js
из partial
, вот как вы могли это сделать, требуется jQuery
:
<script type="text/javascript">
function scriptToExecute()
{
//The script you want to execute when page is ready.
}
function runWhenReady()
{
if (window.$)
scriptToExecute();
else
setTimeout(runWhenReady, 100);
}
runWhenReady();
</script>
foo="$(tr '[:lower:]' '[:upper:]' <<< ${foo:0:1})${foo:1}"
для вашей ситуации
a='one two three'
a="${a^}"
printf '%s\n' "$a"
# One two three
для каждого слова заглавные буквы первой буквы
a='one two three'
b=( $a ) # $a without quotes
for word in "${b[@]}"; do
c+=( "${word^}" )
done
a="${c[*]}"
printf '%s\n' "$a"
# One Two Three
Вот способ «родных» текстовых инструментов:
#!/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
.
– Charles Duffy
8 March 2017 в 19:01
$ foo="bar";
$ foo=`echo ${foo:0:1} | tr '[a-z]' '[A-Z]'`${foo:1}
$ echo $foo
Bar
Один способ с bash (версия 4 +):
foo=bar
echo "${foo^}"
печатает:
Bar
"${foo,}"
. Для ввода всех букв используйте "${foo,,}"
. Для прописных букв используйте буквы "${foo^^}"
.
– Steve
16 December 2015 в 22:37
foo
.
– Steve
21 October 2016 в 00:59
Это можно сделать и в чистом bash с 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
– OZZIE
20 January 2017 в 17:01
=
в назначениях. Это то, что shellcheck.net найдет для вас программно.
– Charles Duffy
8 March 2017 в 19:00
=
в качестве аргумента в программу (как это должно знать, работает ли someprogram =
someprogram
или присвоение переменной с именем someprogram
?)
– Charles Duffy
10 March 2017 в 04:38
Что делать, если первый символ не является буквой (но есть вкладка, пробел и скрытая двойная кавычка)? Нам лучше проверить это, пока мы не найдем письмо! Итак:
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=
$[...]
). Вы используете много бесполезных круглых скобок. Вы предполагаете, что строка состоит из символов латинского алфавита (как насчет акцентированных букв или букв в других алфавитах?). У вас есть много работы, чтобы сделать этот снипп полезным! (и поскольку вы используете регулярное выражение, вы можете также использовать регулярное выражение, чтобы найти первую букву вместо цикла).
– gniourf_gniourf
8 March 2017 в 19:05
tr
: if [[ $S =~ ^([^[:alpha:]]*)([[:alpha:]].*) ]]; then out=${BASH_REMATCH[1]}${BASH_REMATCH[2]^}; else out=$S; fi; printf '%s\n' "$out"
– gniourf_gniourf
9 March 2017 в 10:51
echo $foo
является примером ситуации, когда парсер ожидает список слов ; поэтому в вашем echo ${F}
содержимое F
является разделенным по строкам и glob-расширенным. Это аналогично для примера echo ${S:$N:1}
и всего остального. См. BashPitfalls # 14 .
– Charles Duffy
10 March 2017 в 04:45
Это работало для меня:
Поиск всего * php-файла в текущем каталоге и замена первого символа каждого имени файла на заглавную букву:
например: test. php => Test.php
for f in *php ; do mv "$f" "$(\sed 's/.*/\u&/' <<< "$f")" ; done
Один из способов с sed
:
echo "$(echo "$foo" | sed 's/.*/\u&/')"
Отпечатки:
Bar
brew install coreutils gnu-sed
и следуйте инструкциям, чтобы использовать команды без префикса g
. Для чего это стоит, я никогда не хотел запускать OSX-версию этих команд с момента получения версий GNU.
– Dean
26 August 2014 в 20:01
sed 's/./\U&/
, и он будет работать на POSIX sed.
– David Conrad
26 May 2017 в 15:29
Использование awk только
foo="uNcapItalizedstrIng"
echo $foo | awk '{print toupper(substr($0,0,1))tolower(substr($0,2))}'
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}
notQuiteCamel
наNotQuiteCamel
. Ваш вариант имеет побочный эффект или принуждение остальных к нижнему регистру - за счет удвоения количества подклассов и tr процессов. – Jesse Chisholm 27 July 2016 в 20:54bash
. – Charles Duffy 10 March 2017 в 04:48