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}:提取最左边的5 个字节:/dir1
    ${file:5: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

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

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

  • 相关阅读:
    echarts曲线图
    echarts画柱状图
    echarts画环形图
    ppt素材网
    黄元御的桔梗元参汤治疗过敏性鼻炎
    vue双向数据绑定对于数组和新增对象属性不能监听的解决办法
    谈谈vue双向数据绑定问题
    一个不错的中医博客
    javascript 中 keyup、keypress和keydown事件
    浏览器渲染页面的过程
  • 原文地址:https://www.cnblogs.com/sheng-247/p/14372209.html
Copyright © 2011-2022 走看看