输入一串随机数字,然后按千分位输出。

比如输入数字串为“123456789”,输出为123,456,789

#!/bin/bashread -p "输入一串数字:" numv=`echo $num| sed 's/[0-9]//g'`if [ -n "$v" ]then    echo "请输入纯数字。"    exitfilength=${#num} #表示num字符串的长度len=0sum=''for i in $(seq 1 $length) #可写为`seq 1 $length`do    len=$[$len+1]    if [[ $len == 3 ]]    then        sum=','${num:$[0-$i]:1}$sum         #这里$[0-$i]也可改为0-$i         #这里可以看为3个部分,','为一个部分,${num:$[0-$i]:1}为一个部分,$sum为为一个部分        len=0    else        sum=${num:$[0-$i]:1}$sum    fidoneif [[ -n $(echo $sum | grep '^,')  ]] #判断是否是以“,”开头的行,如果是以“,”开头,可能类似“,123”的形式,所以要打印下标从1开始的数组(下标默认是从0开始)。then     echo ${sum:1}else     echo $sumfi

解析:

 read -p 将输入变量赋值给变量num

-n string 如果 string长度非零,则为真 [ -n "$myvar" ]

${#num}获取(num)字符串的长度

sum=','${num:$[0-$i]:1}$sum   将这个拆开看就好理解了,sum=','(单独的,)${num:${0-$i}:1}(切片数组)$sum(变量$sum的值)

${num:$[0-$i]:1},直接通过 ${数组名[@或*]:起始位置:长度}     切片原先数组,$[0-$i]就是起始位置,如果数值是0或正数,就从左到右数,下标依次为0,1,2,3.....,如果数值是负数,就从右往左数,下标依次为......-4,-3-2,-1,最后的长度为,从下标起始位置从左往右开始数,长度是多少就数到第几个

例如:

[root@bastion-IDC ~]# a=(1 2 3 4 5 6 7 8)[root@bastion-IDC ~]# echo ${a[@]:1:4}2 3 4 5
[root@bastion-IDC ~]# a=(1 2 3 4 5 6 7 8)[root@bastion-IDC ~]# echo ${a[@]:0-3:2}6  7#0-3的值为-3,这里不能直接写-3

^表示行的开始,所以grep '^,'表示打印以“,”开头的行

主要是for循环这一段。如果输入num的值为12345,那么for循环中的i需要从1遍历到5

当i=1时
当i=2时
当i=3时
当i=4时
当i=5时
则len=1(len=0+1)
则len=2(len=1+1)
则len=3(len=2+1) 则len=1(len=0+1) 则len=2(len=1+1)
if判断len不等于3,执行elif
if判断len不等于3,执行elif if判断len=3,条件成立
if判断len不等于3,执行elif if判断len不等于3,执行elif
则sum=${num:0-1:1}$sum,结果为sum=5与空($sum的值),所以sum=5
则sum=${num:0-2:1}$sum,结果为sum=4与 5($sum的值),所以sum=45 则sum=‘,’${num:0-3:1}$sum,结果为sum=,与3与 45($sum的值),所以sum=,345 则sum=${num:0-4:1}$sum,结果为sum=2与,345($sum的值),所以sum=2,345 则sum=${num:0-5:1}$sum,结果为sum=1与2,345($sum的值),所以sum=12,345