zoukankan      html  css  js  c++  java
  • shell中的${},##和%%的使用

    假设我们定义了一个变量为:
    file=/dir1/dir2/dir3/my.file.txt

    可以用${ }分别替换得到不同的值:
    ${file#*/}:删掉第一个及其左边的字符串:dir1/dir2/dir3/my.file.txt
    ${file##*/}:删掉最后一个/  及其左边的字符串:my.file.txt
    ${file#*.}:删掉第一个.  及其左边的字符串:file.txt
    ${file##*.}:删掉最后一个.  及其左边的字符串:txt
    ${file%/*}
    :删掉最后一个 /  及其右边的字符串:/dir1/dir2/dir3
    ${file%%/*}:删掉第一个/  及其右边的字符串:(空值)
    ${file%.*}:删掉最后一个 .  及其右边的字符串:/dir1/dir2/dir3/my.file
    ${file%%.*}:删掉第一个 .   及其右边的字符串:/dir1/dir2/dir3/my

    记忆的方法为:
    # 是 去掉左边(键盘上#在 $ 的左边)
    %是去掉右边(键盘上% 在$ 的右边)
    单一符号是最小匹配;两个符号是最大匹配
    ${file:0:5}:提取最左边的个字节:/dir1
    ${file:5:5}
    :提取第个字节右边的连续5个字节:/dir2

    也可以对变量值里的字符串作替换:
    ${file/dir/path}
    :将第一个dir 替换为path/path1/dir2/dir3/my.file.txt
    ${file//dir/path}
    :将全部dir 替换为path/path1/path2/path3/my.file.txt

    利用${ } 还可针对不同的变数状态赋值(沒设定、空值、非空值) 
    ${file-my.file.txt} 
    :假如$file 沒有设定,則使用my.file.txt 作传回值。(空值及非空值時不作处理
    ${file:-my.file.txt} 
    :假如$file 沒有設定或為空值,則使用my.file.txt 作傳回值。(非空值時不作处理)
    ${file+my.file.txt} 
    :假如$file 設為空值或非空值,均使用my.file.txt 作傳回值。(沒設定時不作处理)
    ${file:+my.file.txt} 
    :若$file 為非空值,則使用my.file.txt 作傳回值。(沒設定及空值時不作处理)
    ${file=my.file.txt} 
    :若$file 沒設定,則使用my.file.txt 作傳回值,同時將$file 賦值為my.file.txt (空值及非空值時不作处理)
    ${file:=my.file.txt} 
    :若$file 沒設定或為空值,則使用my.file.txt 作傳回值,同時將$file 賦值為my.file.txt (非空值時不作处理)
    ${file?my.file.txt} 
    :若$file 沒設定,則將my.file.txt 輸出至STDERR(空值及非空值時不作处理)

    ${file:?my.file.txt} :若$file 没设定或为空值,则将my.file.txt 输出至STDERR(非空值時不作处理)

    ${#var} 可计算出变量值的长度:

    ${#file} 可得到27 ,因为/dir1/dir2/dir3/my.file.txt 27个字节

    转自:http://space.baidu.com.cn/ugo5/blog/item/c550bbc54d1644079c163dbd.html

  • 相关阅读:
    SAP ALE 事务代码
    jquery插件——仿新浪微博限制输入字数的textarea
    《响应式web设计》读书笔记(五)CSS3过渡、变形和动画
    《响应式web设计》读书笔记(四)HTML5与CSS3
    MySQL 数据类型
    深入理解JavaScript中的this关键字
    SQL Server 存储过程、触发器、游标
    SQL Server 视图
    SQL Server表的创建及索引的控制
    SQL Server 查询语句(二)
  • 原文地址:https://www.cnblogs.com/robbychan/p/3786518.html
Copyright © 2011-2022 走看看