生信小白入门Linuxlinux小白相关

Linux常用通配符与参数扩展

2022-04-05  本文已影响0人  Ashu

通配符与参数扩展

通配符:*?!()[]{}
参数扩展:%%%###///:::

通配符

字符 含义 实例
* 匹配 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
fi?e1里?的匹配

中括号[]任意匹配

[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位到倒数第一位,从第三位最后一位不取)
对变量索引
上一篇下一篇

猜你喜欢

热点阅读