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
利用 ${ } 还可针对不同的变数状态赋值(?]设定、空值、非空值):
${file-my.file.txt} :假如 $file ?]有设定,?t使用 my.file.txt 作传回值。(空值及非空值?r不作处理)
${file:-my.file.txt} :假如 $file ?]有?定或?榭罩担?t使用 my.file.txt 作?骰刂怠 (非空值?r不作处理)
${file+my.file.txt} :假如 $file ??榭罩祷蚍强罩担??褂 my.file.txt 作?骰刂怠??]?定?r不作处理)
${file:+my.file.txt} :若 $file ?榉强罩担?t使用 my.file.txt 作?骰刂怠 (?]?定及空值?r不作处理)
${file=my.file.txt} :若 $file ?]?定,?t使用 my.file.txt 作?骰刂担??r? $file ?值? my.file.txt 。 (空值及非空值?r不作处理)
${file:=my.file.txt} :若 $file ?]?定或?榭罩担?t使用 my.file.txt 作?骰刂担??r? $file ?值??y.file.txt 。 (非空值?r不作处理)
${file?my.file.txt} :若 $file ?]?定,?t? my.file.txt ?出至 STDERR。 (空值及非空值?r不作处理)
${file:?my.file.txt} :若 $file 没设定或为空值,则将 my.file.txt 输出至 STDERR。 (非空值?r不作处理)
${#var} 可计算出变量值的长度:
${#file} 可得到 27 ,因为/dir1/dir2/dir3/my.file.txt 是27个字节
[/code]
Shell脚本逐行读取文本文件(不改变文本格式)
网上有很多shellscript读文本文件的例子,但是都没有讲出故事的全部,只说了一半。举个例子,比如从一个testfile文件中读取如下格式的文本行:$vitestfil
Shell脚本配合iptables屏蔽来自某个国家的IP访问
星期六我们一位客户受到攻击,我们的网络监测显示有连续6小时的巨大异常流量,我们立即联系了客户,没有得到回应,我们修改和限制了客户的VPS,
Shell脚本一次读取文件中一行的2种写法
写法一:#!/bin/bashwhilereadlinedoecho$line#这里可根据实际用途变化doneurfile写法二:#!/bin/bashcaturfile|whilereadlinedoecho$linedone注意:以上代码中urfile为被读取的文件S
编辑:一起学习网
标签:字符串,不作,第一个,字节,脚本