通配符与参数扩展
通配符:
*
、?
、!
、()
、[]
、{}
参数扩展:%
、%%
、#
、##
、/
、//
、:
、::
通配符
字符 | 含义 | 实例 | |
---|---|---|---|
* | 匹配 0 或多个字 符 | ab* | a 与b之间可以有任意长度的任意字符,也可以一个 也没有,如ab, aab, acccccdb, a24322qqb。 |
? | 匹配任意单一字符 | a?b | a与b之间必须有一个任意字符,如aqb, acb,a7b。 |
[list] | 匹配list中的任意单一字符 | a[xyz]b | a与b之间必须是list列出的任意一个字符, 如: axb,ayb,azb。 |
[!list] | 匹配除list中的任 意单一字符 | a[!0-9]b | a与b之间必须是除去阿拉伯字符的任意一个字符,如 axb,aab,a-b。 |
[c1-c2] | 匹配 c1-c2 中的 任意单一数字 | a[0-9]b | a与b之间必须是0与9之间的一个字符,如a0b,a1b...a9b 。 |
{string1...} | 匹配 sring1或其 他字符串之一 | a{abc,xyz,123}b | a与b之间只能是abc或xyz或123这三个字符串之一 。 |
通配符:*
、?
、!
、()
、[]
、{}
a*b
类似正则表达式,又和正则表达式不一样
这里的*
与正则表达式里的不一样,正则表达式a*b
,表示a可以是任意多个
touch file{1..10}
##新建10个file文本
ls
ls file*
##*匹配file后任意字符
##grep、awk、sed 的里面的*表示正则表达式
a?b
的演示
##touch meak meal meil meyel meyl
##批量建多个文本
ls
ls me?l
##meal meil meyl,匹配me?l结构。必须是l结尾才被识别,精准匹配
rm -r meak meal meil meyel meyl
##一次性删除多个文件
以上是自己举的例子,还是跟着小郭老师的例子:
touch fiie1
ls
ls fi?e1
##fiie1 file1
中括号[]任意匹配
[list]
ls
ls file[12345]
##file1 file2 file3 file4 file5,[12345]是可以单独出现的,五选一匹配
[!list]
ls
ls file[!12345]
##file6 file7 file8 file9,[!12345]的意思是不要列出含有[12345]任一个
{string1...}
的演示
ls
rm fi*
##批量删除开头带有fi的所有文本
ls
mkdir file{abc,123}
ls
rm -r file*
ls
touch file{1..10}
echo {1..10}
##1 2 3 4 5 6 7 8 9 10,1到10为一个等差序列。
ls
rm file*
ls
注意:删除touch生成的文本用rm file,不需要加-r,删除mkdir生成的文件时,一定要加参数-r,用rm -r file*匹配删除多个file。
通配符只要熟练掌握号的用法*
参数扩展
参数扩展:%
、%%
、#
、##
、
参数扩展 | 含义 |
---|---|
${变量#关键字} | 若变量内容从头开始的数据符合“关键字”,则将符 合的最短数据删除 |
${变量##关键字} | 若变量内容从头开始的数据符合“关键字”,则将符 合的最长数据删除 |
${变量%关键字} | 若变量内容从尾开始的数据符合“关键字”,则将符 合的最短数据删除 |
${变量%%关键字} | 若变量内容从尾开始的数据符合“关键字”,则将符 合的最长数据删除 |
掐头: # 掐掉最短头部,## 掐掉最长头部
去尾:% 去掉最短尾部,%% 去掉最长尾部
#
去掉头部字符串演示
id=Data.tar.gz
echo ${id}
#Data.tar.gz
echo ${id#*ta}
#.tar.gz
##从第一个ta开始匹配的,去掉Data,即去掉最短的头部
echo ${id##*ta}
#r.gz
##去掉长的头部
%去掉尾部字符串演示
id=Data.tar.gz
echo ${id}
#Data.tar.gz
其它参数扩展
/
、//
替换//
参数扩展 | 含义 |
---|---|
${变量 / 旧字符串/ 新字符串} |
若变量内容符合“旧字符串”,则首个旧字符串会被新字符串替换 。 |
${变量// 旧字符串/ 新字符串} |
若变量内容符合“旧字符串”,则全部旧字符串会被新字符串替换 。 |
字符串的替换
id=Data.tar.gz
echo ${id}
##Data.tar.gz
echo ${id/ta/xy}
##Daxy.tar.gz
echo ${id//ta/xy}
##Daxy.xyr.gz
截取:索引位置从 0 开始 id=Data.tar.gz(R语言的下标是从1开始,Linux是从0开始)
参数扩展 ${变量:索引:-n} | 含义 |
---|---|
${变量:索引} | 截取变量从索引位置到末尾的所有字符 |
${变量:索引: n} | 截取变量从索引位置开始的n个字符 |
${变量:索引:(-n)} ; | 截取变量从索引位置到倒数第n+1位的 所有字符 |
${变量:索引:-n}
id=Data.tar.gz
##1D2a3ta4.5t6a7r9.10g11z
echo ${#id}
##11(一共有11位,包括.符号)
echo ${id:3}
##a.tar.gz(从3开始到最后)
echo ${id:3:5}
##a.tar(从3开始到后面的第5个,长度为5,不是从第三个到第五个)
echo ${id:3:-1}
#a.tar.g(第3位到倒数第一位,从第三位最后一位不取)