shell 脚本之获取命令输出字符串以及函数参数传递

本文探讨了Ubuntu 14.04及以后版本中U盘挂载的用户权限问题,并详细介绍了Shell脚本中字符串操作的方法,包括字符串截取、长度获取等实用技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在ubuntu 14.04之后,所有的U盘挂载也分用户之分,最近很多操作也和U盘有关,所以就研究了一上午shell脚本函数以及字符串操作的方法。

字符串操作:

获取他的命令输出比较简单,打个简单的比方,我想获取whoami 的用户名,那么直接可以使用如下代码。
```sh
#!/bin/sh                                                                       
                                                                            
                                                                            
USER_NAME=$(whoami)                                                             
                                                                            
main() {                                                                        
                                                                            
    sudo cp target/*    /media/$USER_NAME/rootfs/ -rf                           
}                                                                               
                                                                            
main                                                                            
```
```sh
#如果你想操作这些字符串的话,那么可以有以下方法
#shell中截取字符串的方法有很多中,
${expression}一共有9种使用方法。
${parameter:-word}
${parameter:=word}
${parameter:?word}
${parameter:+word} 
#上面4种可以用来进行缺省值的替换。

${#parameter}
# 上面这种可以获得字符串的长度。 

${parameter%word} 最小限度从后面截取word
${parameter%%word} 最大限度从后面截取word
${parameter#word} 最小限度从前面截取word
${parameter##word} 最大限度从前面截取word
# 上面4个就是用来截取字符串的方法了。
# 有了着四种用法就不必使用cut命令来截取字符串了

#第一种又可以分为四种情况,下面一一介绍。
#1、使用 # 号操作符。用途是从左边开始删除第一次出现子字符串即其左边字符,保留右边字符。用法为#*substr,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${str#*//}
# 得到的结果为www.你的域名.com/cut-string.html,即删除从左边开始到第一个"//"及其左边所有字符

#2、使用 ## 号操作符。用途是从左边开始删除最后一次出现子字符串即其左边字符,保留右边          字符。用法为##*substr,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${str##*/}    
# 得到的结果为cut-string.html,即删除最后出现的"/"及其左边所有字符

#3、使用 % 号操作符。用途是从右边开始删除第一次出现子字符串即其右边字符,保留左边字符。用法为%substr*,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${str%/*}
# 得到的结果为http://www.你的域名.com,即删除从右边开始到第一个"/"及其右边所有字符

#4、使用 %% 号操作符。用途是从右边开始删除最后一次出现子字符串即其右边字符,保留左边字符。用法为%%substr*,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${str%%/*}
# 得到的结果为http://www.你的域名.com,即删除从右边开始到最后一个"/"及其右边所有字符

# 第二种也分为四种,分别介绍如下:
# 1、从左边第几个字符开始以及字符的个数,用法为:start:len,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${var:0:5}
# 其中的 0 表示左边第一个字符开始,5 表示字符的总个数。
# 结果是:http:

2、从左边第几个字符开始一直到结束,用法为:start,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${var:7}
# 其中的 7 表示左边第8个字符开始
# 结果是:www.你的域名.com/cut-string.html

# 3、从右边第几个字符开始以及字符的个数,用法:0-start:len,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${str:0-15:10}
# 其中的 0-6 表示右边算起第6个字符开始,10 表示字符的个数。    
# 结果是:cut-string

# 4、从右边第几个字符开始一直到结束,用法:0-start,例如:
str='http://www.你的域名.com/cut-string.html'
echo ${str:0-4}
# 其中的 0-6 表示右边算起第6个字符开始,10 表示字符的个数。
# 结果是:html
# 注:(左边的第一个字符是用 0 表示,右边的第一个字符用 0-1 表示)
```sh

函数参数传递

#!/bin/sh

SDCARD_BOOT=/media/chen_7109/boot
SDCARD_ALL=/media/chen_7109/*

# Copy image to sd card boot partition
mycptosd() {
    cp  am335x-sbc7109.dtb  MLO  u-boot.img  uEnv_emmc.txt  uEnv.txt  zImage /media/chen_7109/boot/  -rf
    sync
    echo    "Copy Image to sdcard over ....."
}

# The main function
main () {
    if [ -e $SDCARD_BOOT ]; then
        mycptosd
        if [ 1 -eq $# ]; then
            if [ "$1" = "umount" ]; then
                sudo umount $SDCARD_ALL
            else
                echo "Please input arguments "umount" to umount sd card"
            fi
        else
            echo "You can input arguments of "umount" to umount sd card"
        fi
    else
        echo "No such file of sd card boot partition"
    fi
}


# Main Start ....
if [ 1 -eq $# ];then
    main $1
else
    main
fi
上面这个脚本中,本来要传递到main的一个参数的,我一开始以为在shell  外面直接带一个参数就可以传到main()函数内部,
发现这样是不可以的,shell里面的函数调用的时候参数是独立的参数,所以只能用main $1 的方式将参数传递进去。

转载于:https://www.cnblogs.com/chenfulin5/p/6149230.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值