我想数第一个空格之后的字符数。例如,线可能是这样的:我是一只兔子
N=第一个空格后的字符数是7个(一个兔子),所以我想出了一个方法。也就是说,计算第一个空格之前的字符数和空格本身= P,然后N=行的长度-P=11-4=7( "Iam“的长度为4)
count_first_part() {
line=$1
count=0
echo "$1" | grep -o . >file1.txt
while read -r linee; do
if [[ "$linee" != [^[:space:]] ]]; then
((count++))
else
((count++))
break
fi
done
count_length_of_line() {
string=$1
count=$(echo "$string" | wc -c)
}
p=$(count_first_part "Iam a bunny")
l=$(count_length_of_line "Iam a bunny")
n=$l-$p
echo "$n"
但是,函数count_first_part()返回1,而count_length_of_line()返回length+1 (这是错误的)。有谁可以帮我?
发布于 2019-06-20 19:56:40
如果变量包含字符串:
str="Iam a bunny"
它可能很简单,如:
$ before="${str%% *} "; after=${str#* }
$ echo "\"$before\"=${#before} \"$after\"=${#after}"
"Iam "=4 "a bunny"=7
发布于 2019-06-20 23:26:01
您可以从这里的字符串中将read
放入多个变量:
$ str="Iam a bunny"
$ read -r first rest <<<"$str"
$ echo "${#first} ${#rest}"
3 7
如果需要,可以向first+=" "
这样的第一个位置添加一个空格。
此技术将不包含单词之间的多个空格。
也许一个更健壮的技术是一个正则表达式:
$ if [[ $str =~ ([^[:blank:]]+[[:blank:]]+)(.*) ]]; then
first=${BASH_REMATCH[1]} rest=${BASH_REMATCH[2]}
fi
$ echo "${#first} ${#rest}"
4 7
https://unix.stackexchange.com/questions/526117
复制相似问题