Shell参数扩展形式学习笔记

Shell参数扩展形式学习笔记

文章目录

  • Shell参数扩展形式学习笔记
    • 空值判断处理 ${parameter:-word} ${parameter:=word} ${parameter:?word} ${parameter:+word}
    • 变量位置截取 ${parameter:offset} ${parameter:offset:length}
    • 变量匹配组合 ${!prefix*} ${!prefix@} ${!name[@]} ${!name[*]}
    • 获取长度 ${#parameter}
    • 变量匹配删除 ${parameter#word} ${parameter##word} ${parameter%word} ${parameter%%word}
    • 变量文本替换 ${parameter/pattern/string} ${parameter//pattern/string} ${parameter/#pattern/string} ${parameter/%pattern/string}
    • 大小写转换 ${parameter^pattern} ${parameter^^pattern} ${parameter,pattern} ${parameter,,pattern}
    • 变量特定操作 ${parameter@operator}

在 Bash 的官方文档中,你可以查找关于 Shell 参数扩展的章节,通常位于“3.5.3 Shell Parameter Expansion”章节将提供关于 ${} 语法以及其他参数扩展形式的详细说明和示例。

链接如下:
https://www.gnu.org/software/bash/manual/html_node/Shell-Parameter-Expansion.html

空值判断处理 ${parameter:-word} ${parameter:=word} ${parameter:?word} ${parameter:+word}

举例说明:

这四种 ${} 形式的区别如下:

  1. ${parameter:-word}:如果变量 parameter 未定义或为空,则使用默认值 word,并将其扩展为该值;否则,保持变量 var 的原始值。

    示例:

    var="value"
    echo "${var:-default}"  # 输出 "value"
    unset var
    echo "${var:-default}"  # 输出 "default"
    
  2. ${parameter:=word}:如果变量 parameter 未定义或为空,则将其设置为默认值 word,并将其扩展为该值;否则,保持变量 var 的原始值。

    示例:

    var="value"
    echo "${var:=default}"  # 输出 "value"
    unset var
    echo "${var:=default}"  # 输出 "default"
    
  3. ${parameter:?word}:如果变量 parameter 未定义或为空,则输出错误信息 word 到标准错误输出,并退出脚本;否则,将变量 var 的值扩展为其原始值。

    示例:

    var="value"
    echo "${var:?Variable var is not set.}"  # 输出 "value"
    unset var
    echo "${var:?Variable var is not set.}"  # 输出错误信息到标准错误输出并退出脚本
    
  4. ${parameter:+word}:如果变量 parameter 已经被设置并且不为空,则将其扩展为 word;否则,将其扩展为空字符串。

    示例:

    var="value"
    echo "${var:+default}"  # 输出 "default"
    unset var
    echo "${var:+default}"  # 输出空字符串
    

总结:

  • ${parameter:-word}${parameter:=word} 用于提供默认值,但前者不会改变变量的值,后者会在变量未定义或为空时设置变量的值。
  • ${parameter:?word} 用于检查变量是否已定义,未定义则输出错误信息并退出脚本。
  • ${parameter:+word} 用于检查变量是否已设置并且不为空,是则扩展为指定值,否则扩展为空字符串。

变量位置截取 ${parameter:offset} ${parameter:offset:length}

这两种形式都是 Bash 中的参数扩展形式,用于提取字符串的子串。它们的区别在于提取子串的方式:

  1. ${parameter:offset}:从变量 parameter 的字符串中提取从偏移量 offset 开始的子串,直到字符串的末尾。

    示例:

    str="abcdefg"
    echo "${str:2}"  # 输出 "cdefg",从位置 2 开始提取子串
    
  2. ${parameter:offset:length}:从变量 parameter 的字符串中提取从偏移量 offset 开始,长度为 length 的子串。

    示例:

    str="abcdefg"
    echo "${str:2:3}"  # 输出 "cde",从位置 2 开始提取长度为 3 的子串
    

总结:

  • ${parameter:offset} 提取从偏移量 offset 开始到字符串末尾的子串。
  • ${parameter:offset:length} 提取从偏移量 offset 开始,长度为 length 的子串。

变量匹配组合 ${!prefix*} ${!prefix@} ${!name[@]} ${!name[*]}

这四种形式都是 Bash 中的间接引用形式,用于引用以特定前缀开头的变量名。它们的区别在于展开的方式和结果:

  1. ${!prefix*}:展开以 prefix 开头的所有变量名,并返回由这些变量值组成的字符串列表,每个变量值之间用空格分隔。

    示例:

    var1="value1"
    var2="value2"
    echo "${!var*}"  # 输出 "var1 var2"
    
  2. ${!prefix@}:与 ${!prefix*} 类似,展开以 prefix 开头的所有变量名,并返回由这些变量值组成的字符串列表,每个变量值之间用空格分隔。

    示例:

    var1="value1"
    var2="value2"
    echo "${!var@}"  # 输出 "var1 var2"
    
  3. ${!name[@]}:展开数组 name 中的所有元素,并返回由这些元素值组成的字符串列表,每个元素值之间用空格分隔。

    示例:

    array=("value1" "value2")
    echo "${!array[@]}"  # 输出 "value1 value2"
    
  4. ${!name[*]}:与 ${!name[@]} 类似,展开数组 name 中的所有元素,并返回由这些元素值组成的单个字符串,元素值之间用第一个字符为 IFS 的字符分隔(默认为空格)。

    示例:

    array=("value1" "value2")
    echo "${!array[*]}"  # 输出 "value1 value2"
    

总结:

  • ${!prefix*}${!prefix@} 展开以 prefix 开头的所有变量名,并返回由这些变量值组成的字符串列表,每个变量值之间用空格分隔。
  • ${!name[@]}${!name[*]} 展开数组 name 中的所有元素,并返回由这些元素值组成的字符串列表或单个字符串,元素值之间用空格或 IFS 分隔。

获取长度 ${#parameter}

${#parameter} 是 Bash 中的参数长度扩展形式,用于获取变量 parameter 的长度。这个形式可以用于获取字符串的长度,也可以用于获取数组的元素个数。

示例:

# 获取字符串的长度
str="Hello, world!"
echo "${#str}"  # 输出 "13"

# 获取数组的元素个数
array=("apple" "banana" "orange")
echo "${#array[@]}"  # 输出 "3"

在第一个示例中,${#str} 返回字符串变量 str 的长度,即 13。
在第二个示例中,${#array[@]} 返回数组变量 array 中元素的个数,即 3。

变量匹配删除 ${parameter#word} ${parameter##word} ${parameter%word} ${parameter%%word}

这四种形式都是 Bash 中的模式删除操作,用于从变量值中删除匹配的部分。它们的区别在于匹配的方式和删除的范围:

  1. ${parameter#word}:删除变量 parameter 值开头匹配的最短部分(即最短匹配)。

    示例:

    path="/path/to/file.txt"
    echo "${path#*/}"  # 输出 "path/to/file.txt",删除第一个斜杠及其之前的部分
    
  2. ${parameter##word}:删除变量 parameter 值开头匹配的最长部分(即最长匹配)。

    示例:

    path="/path/to/file.txt"
    echo "${path##*/}"  # 输出 "file.txt",删除最后一个斜杠及其之前的部分
    
  3. ${parameter%word}:删除变量 parameter 值结尾匹配的最短部分(即最短匹配)。

    示例:

    filename="file.txt"
    echo "${filename%.*}"  # 输出 "file",删除最后一个点及其之后的部分
    
  4. ${parameter%%word}:删除变量 parameter 值结尾匹配的最长部分(即最长匹配)。

    示例:

    filename="file.txt"
    echo "${filename%%.*}"  # 输出 "file",删除最后一个点及其之后的部分
    

总结:

  • ${parameter#word}${parameter##word} 用于从变量值的开头匹配删除指定部分,区别在于前者是最短匹配,后者是最长匹配。
  • ${parameter%word}${parameter%%word} 用于从变量值的结尾匹配删除指定部分,区别在于前者是最短匹配,后者是最长匹配。

变量文本替换 ${parameter/pattern/string} ${parameter//pattern/string} ${parameter/#pattern/string} ${parameter/%pattern/string}

这四种形式都是 Bash 中的模式替换操作,用于在变量值中替换匹配的部分。它们的区别在于替换的范围和方式:

  1. ${parameter/pattern/string}:将变量 parameter 值中第一个匹配的 pattern 替换为 string

    示例:

    text="apple banana banana"
    echo "${text/ban/orange}"  # 输出 "apple orangeana banana",只替换第一个匹配的 "ban"
    
  2. ${parameter//pattern/string}:将变量 parameter 值中所有匹配的 pattern 替换为 string

    示例:

    text="apple banana banana"
    echo "${text//ban/orange}"  # 输出 "apple orangeana orangeana",替换所有匹配的 "ban"
    
  3. ${parameter/#pattern/string}:如果变量 parameter 值以 pattern 开头,则将其替换为 string

    示例:

    filename="file.txt"
    echo "${filename/#file/path}"  # 输出 "path.txt",替换开头的 "file"
    
  4. ${parameter/%pattern/string}:如果变量 parameter 值以 pattern 结尾,则将其替换为 string

    示例:

    filename="file.txt"
    echo "${filename/%.txt/.csv}"  # 输出 "file.csv",替换结尾的 ".txt"
    

总结:

  • ${parameter/pattern/string}${parameter//pattern/string} 用于在变量值中进行模式替换,前者替换第一个匹配,后者替换所有匹配。
  • ${parameter/#pattern/string}${parameter/%pattern/string} 用于在变量值的开头和结尾匹配替换,分别替换开头和结尾的匹配部分。

大小写转换 ${parameter^pattern} ${parameter^^pattern} ${parameter,pattern} ${parameter,pattern}

这四种形式都是 Bash 中的大小写转换操作,用于将变量值中匹配的部分进行大小写转换。它们的区别在于转换的方式和范围:

  1. ${parameter^pattern}:将变量 parameter 值中第一个匹配的 pattern 转换为大写。

    示例:

    text="hello world"
    echo "${text^w}"  # 输出 "Hello world",将第一个匹配的 "w" 转换为大写
    
  2. ${parameter^^pattern}:将变量 parameter 值中所有匹配的 pattern 转换为大写。

    示例:

    text="hello world"
    echo "${text^^o}"  # 输出 "hellO wOrld",将所有匹配的 "o" 转换为大写
    
  3. ${parameter,pattern}:将变量 parameter 值中第一个匹配的 pattern 转换为小写。

    示例:

    text="Hello World"
    echo "${text,w}"  # 输出 "hello World",将第一个匹配的 "W" 转换为小写
    
  4. ${parameter,,pattern}:将变量 parameter 值中所有匹配的 pattern 转换为小写。

    示例:

    text="Hello World"
    echo "${text,,o}"  # 输出 "hellO WOrld",将所有匹配的 "o" 转换为小写
    

总结:

  • ${parameter^pattern}${parameter^^pattern} 用于将变量值中的匹配部分转换为大写,分别转换第一个匹配和所有匹配。
  • ${parameter,pattern}${parameter,,pattern} 用于将变量值中的匹配部分转换为小写,分别转换第一个匹配和所有匹配。

变量特定操作 ${parameter@operator}

操作取值:

U 全大写
u 首字母大写
L 全小写
Q 转义字符生成
E 转义字符展开
P 提示符展开
A 变量名和值
K 数组变量名和值
a 属性值
k 数组变量名和值

下面是每个操作的示例:

  1. ${parameter@U}:将变量 parameter 的值中的所有小写字母转换为大写。

    示例:

    text="hello World"
    echo "${text@U}"  # 输出 "HELLO WORLD"
    
  2. ${parameter@u}:将变量 parameter 的值中的第一个字母转换为大写。

    示例:

    text="hello world"
    echo "${text@u}"  # 输出 "Hello world"
    
  3. ${parameter@L}:将变量 parameter 的值中的所有大写字母转换为小写。

    示例:

    text="HELLO WORLD"
    echo "${text@L}"  # 输出 "hello world"
    
  4. ${parameter@Q}:返回对变量 parameter 的值进行转义后的结果,可以用作输入。

    示例:

    text="Hello World"
    echo "${text@Q}"  # 输出 "Hello\ World"
    
  5. ${parameter@E}:将变量 parameter 的值中的反斜杠转义字符展开。

    示例:

    text="Hello\nWorld"
    echo "${text@E}"  # 输出 "Hello
    World"
    
  6. ${parameter@P}:展开变量 parameter 的值,类似于 Bash 提示符展开。

    示例:

    text="Hello World \A"
    echo "${text@P}"  # 输出 "Hello World 14:23"
    
  7. ${parameter@A}:返回一个赋值语句,将重建变量 parameter 的属性和值。

    示例:

    text="Hello World"
    echo "${text@A}"  # 输出 "text='Hello World'"
    
  8. ${parameter@K}:返回变量 parameter 的值,可能被引号引用,但数组的索引和关联数组的键值对将被逐个展开并用引号引用。

    示例:

    array=("key1" "value1" "key2" "value2")
    echo "${array@K}"  # 输出 "key1='value1' key2='value2'"
    
  9. ${parameter@a}:返回变量 parameter 的属性值,表示为一系列标志。

    示例:

    text="Hello World"
    echo "${text@a}"  # 输出 "-"
    

-:变量既没有被引号引用,也不是数组。
q:变量被单引号引用。
Q:变量被双引号引用。
x:变量是被解释的。
X:变量是被不被解释的。
@:变量是数组或者关联数组。
A:变量是被赋值的(assigned)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/604894.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C++:菱形继承与菱形虚拟继承

一、菱形继承 单继承:一个子类只有一个直接父类时称这个继承关系为单继承 多继承:一个子类有两个或以上直接父类时称这个继承关系为多继承 菱形继承:菱形继承是多继承的一种特殊情况,派生类继承自两个间接基类,而这…

MVC与MVVM架构模式

1、MVC MVC:Model-View-Controller,即模型-视图-控制器 MVC模式是一种非常经典的软件架构模式。从设计模式的角度来看,MVC模式是一种复合模式,它将多个设计模式结合在一种解决方案中,从而可以解决许多设计问题。 MV…

C++缺省参数、函数重载、引用

一、缺省参数 1.1缺省参数概念 缺省参数是声明或定义函数时为函数的参数指定一个缺省值。在调用该函数时&#xff0c;如果没有指定实参则采用该形参的缺省值&#xff0c;否则使用指定的实参。 void func(int n 0) {cout << n << endl; }int main() {func();func…

营销H5测试综述

H5页面是营销域最常见的一种运营形式&#xff0c;业务通过H5来提供服务&#xff0c;可以满足用户对于便捷、高效和低成本的需求。H5页面是业务直面用户的端点&#xff0c;其质量保证工作显得尤为重要。各业务的功能实现具有通用性&#xff0c;相应也有共性的测试方法&#xff0…

【C语言】字符函数和字符串函数--超详解

前言&#xff1a; 在编程的过程中&#xff0c;我们经常要处理字符和字符串&#xff0c;为了⽅便操作字符和字符串&#xff0c;C语⾔标准库中提供了 ⼀系列库函数&#xff0c;接下来我们就学习⼀下这些函数。 1. 字符分类函数 C语⾔中有⼀系列的函数是专⻔做字符分类的&#…

Java 线程池之 ThreadPoolExecutor

Java线程池&#xff0c;特别是ThreadPoolExecutor&#xff0c;是构建高性能、可扩展应用程序的基石之一。它不仅关乎效率&#xff0c;还直接关系到资源管理与系统稳定性。想象一下&#xff0c;如果每来一个请求就创建一个新的线程&#xff0c;服务器怕是很快就要举白旗了。而Th…

Web Component fancy-components

css-doodle 组件库 fancy-components 组件库使用 yarn add fancy-components使用&#xff1a; import { FcBubbles } from fancy-components new FcBubbles() //要用哪个就new哪个 new 这里可能会报错eslink,eslintrc.js中处理报错 module.exports {rules: {no-new: off} …

【智能算法应用】基于麻雀搜索算法的二维最大熵图像阈值分割

目录 1.算法原理2.数学模型3.结果展示4.参考文献5.代码获取 1.算法原理 【智能算法】麻雀搜索算法&#xff08;SSA&#xff09;原理及实现 2.数学模型 最大熵法是由 Kapur 于 1985 年所提出的&#xff0c; 该方法的阈值选取标准取决于图像中最大化分 割的目标区域和背景区域…

初学java

注意点 1.使用关键字long的时候&#xff0c;在其赋值的时候要在后面加上大写或者小写的l&#xff0c;个人推荐大写&#xff0c;小写与数‘1’难区分。 2.函数的名字要与文件夹的名字相同&#xff0c;并且文件夹后面一定要有.java。例如这个的名字是Main,函数就得用这个&#x…

python+pycharm安装教程

介绍 Python提供了高效的高级数据结构&#xff0c;还能简单有效地面向对象编程。Python语法和动态类型&#xff0c;以及解释型语言的本质&#xff0c;使它成为多数平台上写脚本和快速开发应用的编程语言&#xff0c;Python解释器易于扩展&#xff0c;可以使用C、C或其他可以通过…

国科大深度学习期末历年试卷

本文借鉴 国科大深度学习复习 深度学习期末 深度学习2020 一&#xff0e;名词解释&#xff08;每个2分&#xff0c;共10分&#xff09; 深度学习&#xff0c;稀疏自编码器&#xff0c;正则化&#xff0c;集成学习&#xff0c;Dropout 二&#xff0e;简答题&#xff08;每题…

Autoxjs 实践-Spring Boot 集成 WebSocket

概述 最近弄了福袋工具&#xff0c;由于工具运行中&#xff0c;不好查看福袋结果&#xff0c;所以我想将福袋工具运行数据返回到后台&#xff0c;做数据统计、之后工具会越来越多&#xff0c;就弄了个后台&#xff0c;方便管理。 实现效果 WebSocket&#xff1f; websocket是…

机器学习:基于TF-IDF算法、决策树,使用NLTK库对亚马逊美食评论进行情绪分析

前言 系列专栏&#xff1a;机器学习&#xff1a;高级应用与实践【项目实战100】【2024】✨︎ 在本专栏中不仅包含一些适合初学者的最新机器学习项目&#xff0c;每个项目都处理一组不同的问题&#xff0c;包括监督和无监督学习、分类、回归和聚类&#xff0c;而且涉及创建深度学…

论文阅读】 ICCV-2021-3D Local Convolutional Neural Networks for Gait Recognition

motivation :现有方法方法无法准确定位身体部位&#xff0c;不同的身体部位可以出现在同一个条纹(如手臂和躯干)&#xff0c;一个部分可以出现在不同帧(如手)的不同条纹上。其次&#xff0c;不同的身体部位具有不同的尺度&#xff0c;即使是不同帧中的同一部分也可以出现在不同…

【光速上手 Hydra 】一行代码自动跑多次实验,Hydra 中的 Multirun 参数如何使用?

Hydra 是一个开源的 Python 框架&#xff0c;简化了研究和其他复杂应用的开发。其关键特性是能够通过组合动态地创建一个分层次的配置&#xff0c;并通过配置文件和命令行进行覆盖。Hydra 的名称来源于其能够运行多个类似的作业 - 就像一个有多个头的九头蛇一样。 主要特性&am…

泽众财务RPA机器人常见五个应用场景

泽众RPA&#xff08;即机器人流程自动化&#xff0c;Robotic Process Automation, RPA&#xff09;解决方案是依托于各类先进信息技术手段的虚拟劳动力 &#xff08;数字劳动力&#xff09;&#xff0c;根据预先设定的程序操作指令对任务进行自动化处理&#xff0c;实现业务流程…

解锁机械之美:发动机设备拆解可视化揭秘

在现代工程技术的世界里&#xff0c;发动机作为机械设备的心脏&#xff0c;始终扮演着至关重要的角色。图扑的发动机设备拆解可视化技术&#xff0c;以其独特的视角和精确的细节&#xff0c;为我们开启了一扇了解复杂机械结构的新窗。通过高清晰度的三维图像和动画&#xff0c;…

在阿里云K8S容器中,部署websocket应用程序的总结

一、背景 有一个websocket应用程序&#xff0c;使用spring boot框架开发&#xff0c;http端口号是6005&#xff0c;提供的是websocket服务&#xff0c;所以它还监听一个8889端口的tcp协议。 现在要把它部署到阿里云的k8s容器里&#xff0c;本文着重描述service层的配置。 因…

鸿蒙开发接口Ability框架:【 (ServiceExtensionAbility)】

ServiceExtensionAbility ServiceExtensionAbility模块提供ServiceExtension服务扩展相关接口的能力。 说明&#xff1a; 本模块首批接口从API version 9开始支持。后续版本的新增接口&#xff0c;采用上角标单独标记接口的起始版本。 本模块接口仅可在Stage模型下使用。 导入…

【linux软件基础知识】-死锁问题

死锁问题 当两个或多个线程由于每个线程都在等待另一个线程持有的资源而无法继续时,就会发生死锁 如下图所示, 在线程 1 中,代码持有了 L1 上的锁,然后尝试获取 L2 上的锁。 在线程 2 中,代码持有了 L2 上的锁,然后尝试获取 L1 上的锁。 在这种情况下,线程 1 已获取 L…
最新文章