$0:当前Shell程序的文件名
dirname $0,获取当前Shell程序的路径
cd `dirname $0`,进入当前Shell程序的目录
echo "hvkjvk" >/dev/null 将输出内容删除
清空文件内容
cat /dev/null > filename
(转)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
(转)统计当前文件夹下的文件个数、目录个数
1) 统计当前文件夹下文件的个数:
ls -l |grep "^-"|wc -l
2) 统计当前文件夹下目录的个数:
ls -l |grep "^d"|wc -l
3) 统计当前文件夹下文件的个数,包括子文件夹里的 :
ls -lR|grep "^-"|wc -l
4) 统计文件夹下目录的个数,包括子文件夹里的:
ls -lR|grep "^d"|wc -l
说明:
ls -l :
长列表输出当前文件夹下文件信息(注意这里的文件,不同于一般的文件,可能是目录、链接、设备文件等);
grep "^-" :
这里将长列表输出信息过滤一部分,只保留一般文件,如果只保留目录就是 ^d
wc -l :
统计输出信息的行数,因为已经过滤得只剩一般文件了,所以统计结果就是一般文件信息的行数,又由于一行信息对应一个文件,所以也就是文件的个数。
文件名重命名
ls|rename '.jpg' '.txt' *
例1 修改当前目录下所有文件后缀为txt
n="$(cd "`dirname "$0"`"; pwd)"
for file in $n/*
do echo $file
mv $file ${file%.*}.txt
done
#read -p "Enter your name:" name
#echo "hello,$name"
例2 随机数1-n
#n=$(((RANDOM%100)+1))
#echo $n
:<<EOF
计算1-100的和
for i in `seq 1 100`
do echo -n "$i+$j="
j=$(($j+$i))
echo $j
done
echo $j
#新建100个用户
for i in `seq 1 100`
do
if (i==100)
then echo user_$i
else
echo user_0$i
fi
done
EOF
#删除当前目录下大小为0的文件
for file in `ls`
do
if test -d $file
then echo ""
else
echo $file
a=`ls -l $file | awk '{print $5}'`
if test $a -eq 0
then rm $file
fi
fi
done