Shell命令文件操作命令小结
显示文本文档中某几行:
显示第n行:
sed -n 'np' test.txt
或 head -n test.txt |tail -1
显示第m到第n行:
sed -n 'm,np' test.txt
或 head -n test.txt | tail -(n-m)
显示某一文件夹folder/下所占存储空间:
du -sh folder/
删除某文件夹下的特定文件:
例:删除某文件加下的软连接文件
rm -f `ls -l|grep ^l|awk `{print $8}`
返回上次进入的目录:cd -
删除一个文本文档中所有内容:
切换到命令行模式
:1,$d
使用rm删除一个目录下的除了ttt以外的所有文件
解决:
1. ls | grep -v ttt | xargsrm {}
2. ls | grep -v ttt | xargsrm
3. mvttt /tmp/ &&rm -rf * && mv /tmp/ttt ./
4. find . -name e -prune -o -print | xargsrm -rf
5. find . -name e -prune -o -name dir -prune -o -print | xargsrm -rf {}
6. 删除目录下的除去ttt和目录外所有文件
d=/tjy/
fori in `ls $d`; do
if [ $i != "ttt" ];then
j=`file $d$i | awk '{print $2}'`
if [ $j != "directory" ];then
rm -rf $d$i
fi
fi
done
利用shell命令分割文件:
系统运维的过程中,日志文件往往非常大,这样就要求对日志文件进行分割,在此特用shell脚本对文件进行分割
方法一:
#!/bin/bash
linenum=`wc -l httperr8007.log| awk '{print $1}'`
n1=1
file=1
while [ $n1 -lt $linenum ]
do
n2=`expr $n1 + 999`
sed -n "${n1}, ${n2}p" httperr8007.log > file_$file.log
n1=`expr $n2 + 1`
file=`expr $file + 1`
done
其中httperr8007.log为你想分割的大文件,file_$file.log 为分割后的文件,最后为file_1.log,file_2.log,file_3.log……,分割完后的每个文件只有1000行(参数可以自己设置) 方法二:
split 参数:
-b :后面可接欲分割成的档案大小,可加单位,例如 b, k, m 等;
-l :以行数来进行分割;
#按每个文件1000行来分割除
split -l 1000 httperr8007.log httperr
httpaa,httpab,httpac ........
#按照每个文件100K来分割
split -b 100k httperr8007.log http
httpaa,httpab,httpac ........
使用alias来自定义命令
还有一个使工作变得轻松的方法是使用命令别名。命令别名通常是其他命令的缩写,用来减少键盘输入。
命令格式为:
alias [alias-name=’original-command’]
其中,alias-name是用户给命令取的别名,original- command是原来的命令和参数。需要注意的是,由于Bash是以空格或者回车来识别原来的命令的,所以如果不使用引号就可能导致Bash只截取第一个字,从而出现错误。如果alias命令后面不使用任何参数,则显示当前正在使用的被别名化的命令及其别名。为命令取的别名在该次登录期间始终有效。如果用户需要别名在每次登录时都有效,那么就将alias命令写到初始化脚本文件中。
这是一些很多人认为有用的别名,可以把它们写入初始化脚本文件中来提高工作效率: alias ll=’ls –l’
alias log=’logout’
alias ls=’ls –F’
如果您是一名DOS用户并且习惯了DOS命令,可以用下面的别名定义使 Linux表现得象DOS一样:
aliasdir=’ls’
alias copy=’cp’
alias rename=’mv’
alias md=’mkdir’
alias rd=’rmdir’
注意:在定义别名时,等号两边不能有空格,否则shell不能决定您需要做什么。仅在命令中包含空格或特殊字符时才需要引号。如果键入不带任何参数的alias命令,将显示所有已定义的别名。
第二篇:Shell 循环语句用法小结
在写shell脚本时,常常会用到循环语句。这里简单总结下常用的3种循环语句,以便以后能快速地参考写出,废话不说,开始demo:
1、for
主要用于:在以知序列里遍历元素
[plain] view plaincopy #! /bin/sh -
if [ $# -ge 1 ]; then path=$@ else path=*.sh fi
for i in $path do ls -lh $i done注意:for循环的in列表时可选的,如果省略,shell会遍历整个命令行参数,此时 for i 相当于 for i in "$@"
再给一个for的用法示例:
[plain] view plaincopy #! /bin/sh -
for i in `seq 1 9` do echo $i done注意:for in 可以和 `` 与 $() 合用
再给一个for的用法示例:
[plain] view plaincopy #! /bin/sh -
for i in {a……z} do echo $i done
注意:for in 的大括号{}具有自动补齐功能,大括号与要补齐的内容之间不能有空格,要补齐的内容首尾由两个……相连,其间不能有空格再给个for的用法示例:
[plain] view plaincopy #! /bin/sh -
for (( i=1; i<=10; i++ ))
do echo $i done提醒:这个主要是用了(())
2、while
主要用于:当某条件成立时,一直执行
[plain] view plaincopy #! /bin/sh -
cnt=9
while [ $cnt -ge 0 ] do echo $((cnt——)) done 注意:1、算术运算,需要放在$(()) 的括号中 2、对于变量的算术运算,在$(())中,变量前面不需要$ 3、unitl 主要用于:当某条件成立时,停止执行 [plain] view plaincopy #! /bin/sh - cnt=9 until [ $cnt -lt 0 ] do echo $cnt cnt=$((cnt - 1)) done 注意:给变量赋值时,前面不要加$