1. echo_printf_usage.sh: echo和printf的用法

#! /bin/bash# echo和printf的用法# echo是用于终端打印的基本命令.在默认情况下,echo在每次调用后会添加一个换行符
echo "hello, beijing"
echo "$(pwd)"
echo '$(pwd)' # 结果并不是希望得到的,将会输出: $(pwd)
echo $(pwd) # 输出结果同 echo "$(pwd)"# 在默认情况下,echo会将一个换行符追加到输出文本的尾部.可以使用标志”-n”来忽略结尾的换行符
echo -n  what is your name?
echo 'hello, spring'# 如果需要使用转义序列,则采用echo -e 这种形式
echo -e "1\t2\t3"
echo "\"china beijing\""# 显示结果定向至文件
echo "csdn blog: https://blog.csdn.net/fengbingchun" > a.txt# 反引号用于执行命令
echo  "date: `date`"# printf是另一个可用于终端打印的命令,它使用的参数和C语言中的printf函数一样
# 默认printf不会像echo自动添加换行符,我们可以手动添加\n
# %-10s 指一个宽度为10个字符(-表示左对齐,没有则表示右对齐),任何字符都会被显示在10个字符宽的字符内,如果不足则自动以空格填充,超过也会将内容全部显示出来
printf "hello, world\n"
printf "%-5s %-10s %-4s\n" No Name Mark
printf "%-5s %-10s %-4.2f\n" 1 Sarath 80.3456
printf "%-5s %-10s %-4.2f\n" 2 James 90.9989
printf "%-5s %-10s %-4.2f\n" 3 Jeff 77.564val=5
printf "val: %d\n" ${val}

2. input_output_redirection_usage.sh:输入输出重定向的使用

​#! /bin/bash# 输入输出重定向的使用# 重定向一般通过在命令间插入特定的符号来实现
# command > file : 将输出重定向到file
# command < file : 将输入重定向到file
# command >> file : 将输出以追加的方式重定向到file
# n > file : 将文件描述符为n的文件重定向到file
# n >> file : 将文件描述符为n的文件以追加的方式重定向到file
# n >& m : 将输出文件m和n合并
# n <& m : 将输入文件m和n合并
# << tag : 将开始标记tag和结束标记tag之间的内容作为输入
# 文件描述符0通常是标准输入(STDIN),1是标准输出(STDOUT),2是标准错误输出(STDERR)if [ $# != 1 ]; thenecho "usage: $0 file_name"echo "e.g: $0 ./a.txt"exit 1
fi# 输出重定向:注意任何${1}内的已经存在的内容将被新内容替代.如果要将新内容添加在文件末尾,需要使用>>操作符
echo `who` > ${1}
echo `pwd` >> ${1}# 输入重定向:

3. parameter_usage.sh:参数的使用

​#! /bin/bash# 参数的使用# 我们可以在执行Shell脚本时,向脚本传递参数,脚本内获取参数的格式为:$n. n代表一个数字,1为执行脚本的第一个参数,2为执行脚本的第二个参数,以此类推if [ $# != 3 ]; thenecho "usage: $0 param1 param2 param3"echo "e.g: $0 1 2 3"exit 1
fiecho "执行文件名: $0"
echo "param1: $1"; echo "param2: $2"; echo "param3: $3"# 特殊字符用来处理参数
# $#: 传递到脚本的参数个数
echo "参数个数为: $#"
# $*: 以一个单字符串显示所有向脚本传递的参数
echo "传递的参数作为一个字符串显示: $*"
# $@: 与$*相同,但是使用时加引号,并在引号中返回每个参数
echo "传递的参数作为字符串显示: $@"for i in "$*"; do # 循环一次echo "loop"; echo $i
doneecho ""
for i in "$@"; do # 循环三次echo "loop"; echo $i
done

4. variable_usage.sh:变量的用法

​#! /bin/bash# 变量的用法# 脚本语言通常不需要在使用变量之前声明其类型.只需要直接赋值就可以了.在Bash中,每一个变量的值都是字符串
# 无论你给变量赋值时有没有使用引号,值都会以字符串的形式存储.
# 有一些特殊的变量会被shell环境和操作系统环境用来存储一些特别的值,这类变量被称为环境变量# 变量名的命名须遵循如下规则:
#   变量名和等号之间不能有空格;命名只能使用英文字母,数字和下划线,首个字符不能以数字开头;
#   中间不能有空格,可以使用下划线"_"; 不能使用标点符号; 不能使用bash里的关键字.# 运行shell时,会同时存在三种变量
#   局部变量:在脚本或命令中定义,仅在当前shell实例中有效,其他shell启动的程序不能访问局部变量
#   环境变量:所有的程序,包括shell启动的程序,都能访问环境变量,有些程序需要环境变量来保证其正常运行.必要的时候shell脚本也可以定义环境变量
#   shell变量:是由shell程序设置的特殊变量.shell变量中有一部分是环境变量,有一部分是局部变量,这些变量保证了shell的正常运行# 如果value不包含任何空白字符(如空格),那么它不需要使用引号进行引用,反之,则必须使用单引号或双引号
var=value # var = value 是错误的, "="两边不能有空格# 变量名外面的花括号是可选的,加不加都行,加花括号是为了帮助解释器识别变量的边界
# 推荐给所有变量加上花括号
echo $var # 注意echo $(var) 是错误的
echo ${var}fruit=apple
count=5
echo "We have $count ${fruit}(s)"# 已定义的变量,可以被重新定义
var=1234567890
echo ${#var} # 获得变量值的长度# 环境变量
echo "PATH: ${PATH}"
echo "HOME: ${HOME}"
echo "PWD: ${PWD}"
echo "USER: ${USER}"
echo "UID: ${UID}"
echo "SHELL: ${SHELL}"# 除了显式地直接赋值,还可以用语句给变量赋值
# 将 /etc 下目录的文件名循环出来
for file in `ls /etc`; doecho ${file}
donefor file in $(ls .); doecho ${file}
done# 只读变量:使用readonly命令可以将变量定义为只读变量,只读变量的值不能被改变
readonly var; #var=2 # Error: var: readonly variable# 删除变量:使用unset命令可以删除变量,变量被删除后不能再次使用。unset命令不能删除只读变量
unset count; echo "count: ${count}"
unset var; echo "var: ${var}" # Error: var: cannot unset: readonly variable

5. string_usage.sh:字符串的使用

​#! /bin/bash# 字符串的使用# 字符串可以用单引号,也可以用双引号,也可以不用引号# 单引号:
str='this is a string'; echo "${str}"
# 单引号字符串的限制:
#   单引号里的任何字符都会原样输出,单引号字符串中的变量是无效的
#   单引号字串中不能出现单引号(对单引号使用转义符后也不行)
echo '${str}' # print: ${str}# 双引号: 双引号里可以有变量;双引号里可以出现转义字符# 拼接字符串
var1="hello"; var2="beijing"
var3="hi, ${var1}, ${var2}!"; echo "${var3}"# 获取字符串长度
echo "var3 length: ${#var3}"# 抓取子字符串
# 从var3字符串第2个字符开始截取4个字符
echo "${var3}"; echo "${var3:1:4}"# 查找子字符串: 注意:找出字符串中字符第一次出现的位置,若找不到则expr index返回0. 注意它匹配的是字符而非字符串
echo "${var3}"; echo `expr index "${var3}" i`

6. operator_usage.sh:运算符的使用

​#! /bin/bash# 运算符的使用# expr是一款表达式计算工具,使用它能完成表达式的求值操作,可以用于基本算数操作
# 注意:表达式和运算符之间要有空格; 完整的表达式要被` `包含
val1=3; val2=5
val=`expr ${val1} + ${val2}`
echo "val = ${val}"# let命令可以直接执行基本的算数操作.当使用let时,变量名之前不需要再添加”$”.
# 操作符”[]”的使用方法和let命令类似.也可以使用”(())”,但使用”(())”时,变量名之前需要加上$
let ret=val1+val2
echo "ret: ${ret}"ret=$((val1*val2))
echo "ret: ${ret}"# expr和let都不支持浮点运算,bc支持浮点运算
ret=`echo "${val1} * 1.5" | bc`
echo "ret: ${ret}"# 算术运算符:+、-、×、/、%、=、==、!=
# 注意:条件表达式要放在方括号之间,并且要有空格;乘号(*)前边必须加反斜杠(\)才能实现乘法运算
val=`expr ${val1} \* ${val2}`
echo "val = ${val}"if [ ${val1} == ${val2} ]; thenecho "${val1} 等于 ${val2}"
elseecho "${val1} 不等于 ${val2}"
fi# 关系运算符: -eq、-ne、-gt、-lt、-ge、-le,返回true或false
# 注意:关系运算符只支持数字,不支持字符串,除非字符串的值是数字
if [ ${val1} -lt ${val2} ]; thenecho "${val1} 小于 ${val2}"
elseecho "${val1} 不小于 ${val2}"
fi# 布尔运算符: !(非)、-o(或)、-a(与),返回true或false
if [ ${val1} -eq ${val2} -o ${val1} -lt ${val2} ]; thenecho "${val1} 等于或小于 ${val2}"
elseecho "${val1} 大于 ${val2}"
fi# 逻辑运算符:&&、||,返回true或false
val3=2
if [[ ${val1} -gt ${val3} && ${val2} -ge ${val3} ]]; then # 注意:这里要用两个[[  ]]echo "${val1} > ${val3} 且 ${val2} >= ${val3}"
elseecho "${val1} <= ${val3} 且 ${val2} < ${val3}"
fi# 字符串运算符:=、!=、-z(检测字符串长度是否为0,为0返回true)、-n(检测字符串长度是否为0,不为0返回true)等
str1="abc"; str2="def"; str3=""
if [ ${str1} != ${str2} ]; thenecho "${str1} != ${str2}"
elseecho "${str1} == ${str2}"
fiif [ -z ${str3} ]; thenecho "${str3} 长度为0"
fiif [ -n ${str1} ]; thenecho "${str1} 长度不为0"
fiif [ ${str1} ]; thenecho "${str1} 不为空"
fi# 文件测试运算符:用于检测Unix文件的各种属性
#   -b file: 检测文件是否是块设备文件,如果是,则返回 true
#   -c file: 检测文件是否是字符设备文件,如果是,则返回 true
#   -d file: 检测文件是否是目录,如果是,则返回 true
#   -f file: 检测文件是否是普通文件(既不是目录,也不是设备文件),如果是,则返回 true
#   -g file: 检测文件是否设置了 SGID 位,如果是,则返回 true
#   -r file: 检测文件是否可读,如果是,则返回 true
#   -w file: 检测文件是否可写,如果是,则返回 true
#   -x file: 检测文件是否可执行,如果是,则返回 true
#   -s file: 检测文件是否为空(文件大小是否大于0),不为空返回 true
#   -e file: 检测文件(包括目录)是否存在,如果是,则返回 true
file="./operator_usage.sh"
if [[ -r ${file} && -w ${file} && -x ${file} && -s ${file} && -e ${file} ]]; thenecho "${file} 是可读、可写、可执行的,文件不为空,文件存在   "
fiif [ -f ${file} ]; thenecho "${file} 是普通文件"
fidir="../Samples_Shell"
if [ -d ${dir} ]; thenecho "${dir} 是目录"
fi# test命令用于检查某个条件是否成立,它可以进行数值、字符和文件三个方面的测试
if test ${val1} -le ${val2}; thenecho "${val1} <= ${val2}"
fiif test ${str1} != ${str2}; thenecho "${str1} != ${str2}"
fiif test -r ${file}; thenecho "${file} 可读"
fi

7. if_for_while_case_usage.sh :if, for, while, case的使用

​#! /bin/bash# if、for、while、case的使用# if
val1=5; val2=10
if [ ${val1} == ${val2} ]; thenecho "${val1} == ${val2}"
elif [ ${val1} -gt ${val2} ]; thenecho "${val1} > ${val2}"
elseecho "${val1} < ${val2}"
fi# for
arr=(1 2 3 4 5)
for val in ${arr[@]}; doecho "val ${val}"
done# while
val=1
while (( ${val} <= 5 )); do # 注意是两个((  ))echo "val: ${val}"let val++
done# until: 执行一系列命令直至条件为true时停止
val=1
until [ ! ${val} -lt 5 ]; doecho "val: ${val}"val=`expr ${val} + 1`
done# case
val=4 # 2
case ${val} in1) echo "val = 1" ;;2) echo "val = 2" ;;3) echo "val = 3" ;;*) echo "val is other value" ;;
esac# break
for val in ${arr[@]}; doecho "val: ${val}"if [ ${val} == 2 ]; thenbreakfi
done# continue
for val in ${arr[@]}; doif [ ${val} == 2 ]; thencontinuefiecho "val: ${val}"
done

8. array_usage.sh:数组的使用

​#! /bin/bash# 数组的使用# bash支持一维数组(不支持多维数组),初始化时不需要定义数组大小,并且没有限定数组的大小。
# 类似与C语言,数组元素的下标由0开始编号.获取数组中的元素要利用下标,下标可以是整数或算术表达式,其值应大于或等于0.# 定义数组:在Shell中,用括号来表示数组,数组元素用"空格"符号分割开
arr=(hi bei jing)
echo "${arr[0]} ${arr[1]} ${arr[2]}"
# 也可以单独定义数组的各个分量
arr[1]="tian"
# 读取数组
echo "${arr[0]} ${arr[1]} ${arr[2]}"
# 使用@符号可以获取数组中的所有元素
echo "${arr[@]}"# 获取数组的长度
echo "length: ${#arr[@]}" # 3
echo "length: ${#arr[*]}" # 3
# 取得数组单个元素的长度
echo "sub length: ${#arr[2]}"# 获取数组所有元素的长度
length=0
for i in "${arr[@]}"; dolet length+=${#i}
done
echo "all length: ${length}"

9. function_usage.sh:函数的使用

​#! /bin/bash# 函数的使用# 可以带function fun()定义,也可以直接fun()定义,不带任何参数
# 参数返回,可以显示加:return 返回,如果不加,将以最后一条命令运行结果,作为返回值
fun1() {echo "this is a shell function!"
}echo "调用fun()函数"
# 注意:调用函数仅使用其函数名即可;所有函数在使用前必须定义
fun1#
val=5
echo "val: ${val}"fun2() {let val=val+5
}fun2
echo "val: ${val}"# 函数返回值在调用该函数后通过$?来获得
fun3 () {val1=20; val2=30let val3=val1+val2return ${val3}
}fun3
echo "${val1} + ${val2} = $?"# 函数参数
fun4() {echo "第一个参数为: ${1}"echo "第二个参数为: ${2}"echo "参数总数有 $# 个"echo "作为一个字符串输出所有参数: $*"let val=${1}+${2}echo "val: ${val}"
}fun4 -5 -10

10. read_txt_file_analysis.sh:读取文本文件分析

​#! /bin/bash# 读取txt文件并分析if [ $# != 2 ]; thenecho "usage: $0 src_txt_file dst_txt_file"echo "e.g: $0 ./a.txt ./b.txt"exit 1
fi# 读指定的txt文件,并将每行打印输出
echo "1." >> "$2"
while IFS='' read -r line || [[ -n "$line" ]]; doecho "Text read from file: $line" >> "$2"
done < "$1"# 判断每行中是否含有指定字符,对满足条件的行写入指定的文件
echo "2." >> "$2"
sub="88"
while IFS='' read -r line || [[ -n "$line" ]]; doif [[ "$line" != "${line%$sub*}" ]]; thenecho "${line}" >> "$2"fi
done < "$1"# 如果每行字符长度大于5,则移除每行中最后5个字符,并写入指定的文件
echo "3." >> "$2"
value=5
while IFS='' read -r line || [[ -n "$line" ]]; dolength=${#line}#echo "length: ${length}"if [[ "${length}" -ge "${vale}" ]]; thenecho "${line::-${value}}" >> "$2"fi
done < "$1"# 如果每行字符长度大于10,则移除每行中最前10个字符,并写入指定的文件
echo "4." >> "$2"
value=10
while IFS='' read -r line || [[ -n "$line" ]]; dolength=${#line}if [[ "${length}" -ge "${vale}" ]]; thenecho "${line:${value}}" >> "$2"fi
done < "$1"# 判断每行中是否含有指定字符,若有则用指定的字符替换原有的字符,并写入指定的文件
echo "5." >> "$2"
sub1="group"; sub2="class"
while IFS='' read -r line || [[ -n "$line" ]]; doif [[ "$line" != "${line%$sub1*}" ]]; thenecho ${line} | sed -e "s/${sub1}/${sub2}/g" >> "$2"fi
done < "$1"

11. read_directory_analysis.sh:读取目录文件分析

​#! /bin/bash# 读取目录文件并分析if [ $# != 2 ]; thenecho "usage: $0 src_directory dst_txt_file"echo "e.g: $0 ./a ./a.txt"exit 1
fi# 遍历指定目录(当前层)下所有文件和目录,并写入指定txt文件
echo "1." >> $2
for name in `ls $1`; doecho "name: ${name}" >> $2
done# 遍历指定目录下所有文件,包括子目录下的所有文件,并写入指定txt文件
echo "2." >> $2
for name in $(find $1 -type f -name "*"); doecho "${name}" >> $2
done# 遍历指定目录下所有目录,包括子目录,并写入指定txt文件
echo "3." >> $2
for name in $(find $1 -type d -name "*"); doecho "${name}" >> $2
done# 遍历指定目录下的所有文件,包括子目录下的所有文件,按要求修改文件名字,并写入指定txt文件
echo "4." >> $2
name1="xxx"; name2="yyy"
for name in $(find $1 -type f -name "*${name1}*"); donew_file_name=$(echo ${name} | sed -e "s/${name1}/${name2}/g")echo "${new_file_name}" >> $2mv ${name} ${new_file_name}
done# 遍历指定目录下的所有*.cpp文件,仅将.cpp文件名字并写入指定txt文件,不包括名字前面的路径
echo "5." >> $2
name=`find ${1} -type f -name "*.cpp" -printf "%f\n"` # 注意:需要将-printf放在-name的后面,否则将会查找指定目录下的所有文件
echo "${name}" >> ${2}# 遍历指定目录下带有Samples_*名字的子目录,仅将子目录下带有*.cpp的文件写入指定txt文件,不包括名字前面的路径,并且每个名字单独占一行
echo "6." >> ${2}
for name in $(find ${1} -type d -name "Samples_*"); doecho "dir name: ${name}" >> ${2}echo `find ${name} -type f -name "*.cpp" -printf "%f\n"` | tr " " "\n" >> ${2}
done

12. special_usage.sh:一些特殊使用

​#! /bin/bash
# 在#! /bin/bash后加-x,可以打印较多输出信息,一般在调试定位问题时可以使用# 一些特殊使用# 可以打印较多输出信息,一般在调试定位问题时可以使用,等同于 #! /bin/bash -x
#set -x# ------------------------------
echo "shell name: $0"
# 获取此脚本的绝对路径文件名
real_path=$(realpath $0)
echo "real path: ${real_path}"
# 获取此脚本的绝对路径名
dir_name=`dirname "${real_path}"`
echo "dir_name: ${dir_name}"# ------------------------------
# 调用另一个脚本,注意"."
. array_usage.sh# ------------------------------
# mktemp命令用于建立暂存文件
tmp_dir=`mktemp` # 带绝对路径文件名
tmp_dir=${dir_name}${tmp_dir}
echo "tmp_dir: ${tmp_dir}"
# reference: https://unix.stackexchange.com/questions/137775/how-to-extract-part-of-a-filename-before-or-before-extension
echo "only show tmp_dir name: ${tmp_dir##*/}"# 如果指定目录不存在,则创建
if [[ ! -d ${tmp_dir} ]]; thenmkdir -p ${tmp_dir}
fi# ------------------------------
# 通过find命令查找所有目录,包含子目录
# 注意"%P\n"与"%f\n"的区别,“%P”不包含当前目录即".","%f"包含当前目录
for dir in `find . -type d -printf '%P\n'`; doecho "dir: ${dir}"
done# ------------------------------
# =~: 匹配正则表达式
input1=123; input2=4a6; input3="abcdefg"
if [[ ${input1} =~ [0-9][0-9][0-9] ]]; thenecho "${input1} is number"
elseecho "${input1} is not number"
fiif [[ ${input2} =~ [0-9][0-9][0-9] ]]; thenecho "${input2} is number"
elseecho "${input2} is not number"
fiif [[ ${input3} =~ "cde" ]]; thenecho "${input3} include cde"
elseecho "${input3} don't include cde"
fi# ------------------------------
# reference: http://www.runoob.com/linux/linux-comm-dd.html
# dd命令: 可从标准输入或文件中读取数据,根据指定的格式来转换数据,再输出到文件、设备或标准输出
# 把/dev/null看作"黑洞",它等价于一个只写文件,所有写入它的内容都会永远丢失,而尝试从它那儿读取内容则什么也读不到.然而,/dev/null对命令行和脚本都非常的有用
contents=`dd if=../README.md bs=1 count=17 2>/dev/null` # 禁止标准错误的输出
echo "contents: ${contents}"# ------------------------------
# 通过"%"截断,%后的内容必须是变量name的最后n个字符,否则不起作用
name="/tmp/abc/xyz.jpg"
echo "name: ${name%.jpg}" # /tmp/abc/xyz
# 通过"::"截断最后几个字符
echo "name: ${name::-4}" # /tmp/abc/xyz# ------------------------------
# 通过"##"截断最前面几个字符,##后的内容必须是变量name的最前n个字符,否则不起作用
echo "name: ${name##/tmp}" # /abc/xyz.jpg
# 通过":"截断最前面几个字符
echo "name: ${name:4}" # /abc/xyz.jpg# ------------------------------
# 通过sed解析指定文件中的指定字段,并根据要求写入到另一指定文件中
sed '/typedef struct/,/}/!d;//d' file.txt  | sed 's/x[0-9]://' | sed 's/y[0-9]://' | sed 's/$/,/' # > ./tmp/tmp.txt# ------------------------------
# 通过find查找指定的所有文件,然后通过xargs将所有文件按照要求进行修改
# -I {}的参数:就是在xargs后续命令里,用{}代表xargs之前的命令结果
find . -name "*.sh" | xargs -I {} sed 's/echo/echo -e/' {} > ./tmp/tmp.txt
find . -name "*.sh" | xargs -I {} cp {} ./tmp/# ------------------------------
# $?: 上个命令的退出状态或函数的返回值.一般情况下,大部分命令执行成功会返回0,失败返回非0值
# reference: https://stackoverflow.com/questions/6834487/what-is-the-dollar-question-mark-variable-in-shell-scripting/6834512
status=$?
echo "status: ${status}"
if [[ ${status} != 0 ]]; thenecho "注意:非首次执行上面的命令会返回123:find . -name \"*.sh\" | xargs -I {} cp {} ./tmp/ "#exit ${status}
fiecho "ok!!!"#rm -rf ${tmp_dir}

13. replace_a_string_with_another_string_in_all_files.sh:文件中字符串的替换

​#! /bin/bash# 用指定的字符串替换指定目录下所有文件中需要替换的字符串if [ $# != 3 ]; then  echo "usage: $0 directory_name src_string dst_string"echo "e.g: $0 ./a abcd 1234"exit 1
fifor file_name in `ls $1`; dopath_file_name=$1/${file_name}if [ -f ${path_file_name} ]; thenecho "path_file_name: ${path_file_name}"tmp_file=tmp.txtwhile IFS='' read -r line || [[ -n "$line" ]]; doif [[ "$line" != "${line%$2*}" ]]; thenecho "${line}" | sed -e "s/$2/$3/g" >> ${tmp_file}else   echo "${line}" >> ${tmp_file}# 注意:不是 echo ${line} >> ${tmp_file}# 若 ${line}两边不带双引号,则会将原文件中的空格给移除掉fidone < "${path_file_name}"mv ${tmp_file} ${path_file_name}fi
done

14. analysis_log_file_delete_lines.sh:删除文本文件中含有指定字符串的所有行

#! /bin/bash# 作用:输入源log文件,生成新log文件,新文件是删除了所有行中带有指定字符串的行
# 用法:输入参数依次为:源log文件名字,字符串,新log文件文件名字if [ $# != 3 ]; thenecho "Error: usage: $0 log_file_name string new_log_file_name"echo "e.g: $0 ./log.txt abcd ./new_log.txt"exit 1
fiif [[ ! -e $1 ]]; thenecho "Error: file does not exist: $1"exit 1
fiif [[ -e $3 ]]; thenecho "WARNINT: file exist, first need to delete: $3"rm $3
fiwhile IFS='' read -r line || [[ -n "$line" ]]; doif [[ "$line" == "${line%$2*}" ]]; thenecho "${line}" >> "$3"fi
done < "$1"

15. analysis_log_file_extract_lines.sh:提取出文本文件中含有指定字符串的所有行

#! /bin/bash# 作用:输入源log文件,生成新log文件,新文件是仅含有带有指定字符串的行
# 用法:输入参数依次为:源log文件名字,字符串,新log文件文件名字if [ $# != 3 ]; thenecho "Error: usage: $0 log_file_name string new_log_file_name"echo "e.g: $0 ./log.txt abcd ./new_log.txt"exit 1
fiif [[ ! -e $1 ]]; thenecho "Error: file does not exist: $1"exit 1
fiif [[ -e $3 ]]; thenecho "WARNINT: file exist, first need to delete: $3"rm $3
fiwhile IFS='' read -r line || [[ -n "$line" ]]; doif [[ "$line" != "${line%$2*}" ]]; thenecho "${line}" >> "$3"fi
done < "$1"

以上脚本主要参考:http://www.runoob.com/linux/linux-shell.html

GitHub: https://github.com/fengbingchun/Linux_Code_Test

Shell脚本示例代码相关推荐

  1. 利用shell脚本统计代码行数

    刚毕业那会儿有一次去一家台湾公司面试,问我写过多少行代码.从没想过这个问题,粗略算了算,随口说道:大概几十万行吧.最近整理资料,看着eclipse左边满满的列表,想起了这个事.倒底总共有多少行代码?- ...

  2. 【git】之使用shell脚本提交代码

    为减少提交步骤,防止提交错误,使用Shell脚本进行git提交不失一件好事 #!/bin/sh # @author Hubal # @Email Hubal@123.com # @createBy 2 ...

  3. shell脚本示例:批量比较多个文件的内容是否相同

    bash&shell系列文章:http://www.cnblogs.com/f-ck-need-u/p/7048359.html 要比较两个文件的内容是否完全一致,可以简单地使用diff命令. ...

  4. java ui自动化测试脚本,如何用Airtest编写UI自动化脚本(示例代码)

    前言 游戏并不像app一样直接把渲染树节点暴露出来,这就造成游戏UI自动化在元素定位上的不方便性,不过依赖airtest的图片识别,我们可以直接跳过元素检查,以图片对比的形式进行自动化,虽然效率可能会 ...

  5. linux批量执行一个脚本文件,shell脚本示例:批量比较多个文件的内容是否相同...

    要比较两个文件的内容是否完全一致,可以简单地使用diff命令.例如: diff file1 file2 &>/dev/null;echo $? 但是diff命令只能给定两个文件参数,因此 ...

  6. js动态载入css文件,原生JS动态加载JS、CSS文件及代码脚本(示例代码)

    var DynamciLoadUtil = { // 动态加载外部js文件,并执行回调 loadJS: function(url, callback){ var script = document.c ...

  7. 按键脚本c语言,按键精灵脚本(示例代码)

    1电脑版读取文件脚本Dim path path = "C:/Users/Administrator/Desktop/accounts" //直接读取文件到变量,文件的每一行在变量中 ...

  8. linux毫秒时间差计算,shell脚本示例:计算毫秒级、微秒级时间差

    有时候需要计算命令的执行时间长度,可以使用time命令,虽然time命令可以精确到毫秒级,但time命令无法计算一堆命令的执行时间.可以也可以直接使用date命令计算命令执行前后的时间差,但直接使用d ...

  9. shell 脚本示例

    1.以脚本方式运行:将用户名单里的用户创建出来,存在则显示用户存在,不存在则把用户创建除来 用户名单文件:userfile 脚本 createuser.sh 内容 #!/bin/bash #规定运行环 ...

最新文章

  1. 使命召唤 战区:战术竞技新思路,卷入RPG元素的激烈战斗
  2. 鼠标移动到div上,div中的img放大
  3. IBASE component valid to field
  4. 测试开发——flask视图函数与路由 实战重点
  5. 三天打鱼两天晒网python程序设计_Python经常会遇到三天的笔试题:钓鱼和两天的晒网:,之,三天打鱼,两天晒网...
  6. 周三直播预告丨openGauss和MogDB的优化分享
  7. Python标准库socketserver使用线程混入实现异步TCP服务器
  8. 2021年Node.js开发人员学习路线图
  9. 拓端tecdat|R语言在地图上绘制散点饼图可视化
  10. FISCO BCOS log日志设置配置
  11. 安卓问题报告小记(四):Some projects cannot be imported because they already exist in the workspace...
  12. 职称计算机考试有哪些题,职称计算机考试题库(-套有答案).doc
  13. python数学公式编辑工具_也许是目前最好的数学公式编辑神器——Mathpix Snipping Tool...
  14. 前端 禁止微信调整字体大小
  15. ps手机计算机图标教程,ps制作手机图标的方法
  16. Java LocalDate类| 带示例的getMonth()方法
  17. matlab 直接逆滤波,图像复原之直接逆滤波
  18. APP国际化、动态设置控件颜色(APP个性化)
  19. Oracle表空间碎片查询以及整理
  20. 消息队列中间件 Message Queue 简称:MQ

热门文章

  1. Ubuntu virtualbox
  2. centos7 mysql workbench_centOS下mysql workbench安装配置教程
  3. request中的内容存储_宜信开源|调用链系列(3):解读UAVStack中的调用链技术...
  4. 【杠精】切屏屏蔽和复制,怎么办--有方法解除移动切屏和复制网大限制
  5. hbuilderX的upx单位是什么鬼?
  6. 玻璃和水晶PBR纹理材质预设
  7. UE建筑可视化全局照明学习 Unreal Engine: Global Illumination for Arch. Visualization
  8. LTE: MIB和SIB,小区选择和重选规则
  9. s-systemtap工具使用图谱(持续更新)
  10. Nodejs核心模块之net和http的使用详解