Answers:
foo="$(tr '[:lower:]' '[:upper:]' <<< ${foo:0:1})${foo:1}"
notQuiteCamel
变成NotQuiteCamel
。您的变体会产生副作用或将其余部分强制转换为小写形式-代价是将子shell和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
。自从获得GNU版本以来,我从未想过要运行这些命令的OSX版本。
sed
在这种情况下,您将需要GNU
sed 's/./\U&/
在POSIX sed上使用。
这是“本机”文本工具的方式:
#!/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
范围内的字母的语言/语言环境,则是一个更好的选择。
仅使用awk
foo="uNcapItalizedstrIng"
echo $foo | awk '{print toupper(substr($0,0,1))tolower(substr($0,2))}'
也可以使用bash-3.2在纯bash中完成:
# 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
等等。
资料来源:
简介/教程:
只用首字母大写:
foo='one two three'
foo="${foo^}"
echo $foo
一二三
要大写变量中的每个单词:
foo="one two three"
foo=( $foo ) # without quotes
foo="${foo[@]^}"
echo $foo
Ø NE 牛逼 WO 牛逼重稀土
(适用于bash 4+)
foo='one two three'; foo=$(for i in $foo; do echo -n "${i^} "; done)
每个单词的分辨率更短。foo现在是“一二三”
这个为我工作:
搜索当前目录中的所有* php文件,并将每个文件名的第一个字符替换为大写字母:
例如:test.php => Test.php
for f in *php ; do mv "$f" "$(\sed 's/.*/\u&/' <<< "$f")" ; done
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
}
v-first-leter-to-lower | xclip-选择剪贴板}
如果第一个字符不是字母(而是一个制表符,一个空格和一个转义的双引号)怎么办?我们最好先进行测试,直到找到一封信!所以:
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
例子; 因此,在您的中,的内容是字符串分割和glob-expanded。对于该示例和所有其他示例也是如此。参见BashPitfalls#14。echo ${F}
F
echo ${S:$N:1}