常用脚本命令集
时间:2007-11-11 来源:zhuhuifeng
如何用脚本实现分割文件
[Copy to clipboard] [ - ] CODE:
[Copy to clipboard] [ - ] CODE:
#!/bin/bash
if [ $# -ne 2 ]; then
echo 'Usage: split file size(in bytes)'
exit
fi
file=$1
size=$2
if [ ! -f $file ]; then
echo "$file doesn't exist"
exit
fi
#TODO: test if $size is a valid integer
filesize=`/bin/ls -l $file | awk '{print $5}'`
echo filesize: $filesize
let pieces=$filesize/$size
let remain=$filesize-$pieces*$size
if [ $remain -gt 0 ]; then
let pieces=$pieces+1
fi
echo pieces: $pieces
i=0
while [ $i -lt $pieces ];
do
echo split: $file.$i:
dd if=$file of=$file.$i bs=$size count=1 skip=$i
let i=$i+1
done
echo "#!/bin/bash" >; merge
echo "i=0" >;>; merge
echo "while [ $i -lt $pieces ];" >;>; merge
echo "do" >;>; merge
echo " echo merge: $file.$i" >;>; merge
echo " if [ ! -f $file.$i ]; then" >;>; merge
echo " echo merge: $file.$i missed" >;>; merge
echo " rm -f $file.merged" >;>; merge
echo " exit" >;>; merge
echo " fi" >;>; merge
echo " dd if=$file.$i of=$file.merged bs=$size count=1 seek=$i" >;>; merge
echo " let i=$i+1" >;>; merge
echo "done" >;>; merge
chmod u+x merge'
如何查找日期为某一天的文件
[Copy to clipboard] [ - ] CODE:
if [ $# -ne 2 ]; then
echo 'Usage: split file size(in bytes)'
exit
fi
file=$1
size=$2
if [ ! -f $file ]; then
echo "$file doesn't exist"
exit
fi
#TODO: test if $size is a valid integer
filesize=`/bin/ls -l $file | awk '{print $5}'`
echo filesize: $filesize
let pieces=$filesize/$size
let remain=$filesize-$pieces*$size
if [ $remain -gt 0 ]; then
let pieces=$pieces+1
fi
echo pieces: $pieces
i=0
while [ $i -lt $pieces ];
do
echo split: $file.$i:
dd if=$file of=$file.$i bs=$size count=1 skip=$i
let i=$i+1
done
echo "#!/bin/bash" >; merge
echo "i=0" >;>; merge
echo "while [ $i -lt $pieces ];" >;>; merge
echo "do" >;>; merge
echo " echo merge: $file.$i" >;>; merge
echo " if [ ! -f $file.$i ]; then" >;>; merge
echo " echo merge: $file.$i missed" >;>; merge
echo " rm -f $file.merged" >;>; merge
echo " exit" >;>; merge
echo " fi" >;>; merge
echo " dd if=$file.$i of=$file.merged bs=$size count=1 seek=$i" >;>; merge
echo " let i=$i+1" >;>; merge
echo "done" >;>; merge
chmod u+x merge'
如何查找日期为某一天的文件
[Copy to clipboard] [ - ] CODE:
#!/bin/sh
# The right of usage, distribution and modification is here by granted by the author.
# The author deny any responsibilities and liabilities related to the code.
#
OK=0
A=`find $1 -print`
if expr $3 == 1 >;/dev/null ; then M=Jan ; OK=1 ; fi
if expr $3 == 2 >;/dev/null ; then M=Feb ; OK=1 ; fi
if expr $3 == 3 >;/dev/null ; then M=Mar ; OK=1 ; fi
if expr $3 == 4 >;/dev/null ; then M=Apr ; OK=1 ; fi
if expr $3 == 5 >;/dev/null ; then M=May ; OK=1 ; fi
if expr $3 == 6 >;/dev/null ; then M=Jun ; OK=1 ; fi
if expr $3 == 7 >;/dev/null ; then M=Jul ; OK=1 ; fi
if expr $3 == 8 >;/dev/null ; then M=Aug ; OK=1 ; fi
if expr $3 == 9 >;/dev/null ; then M=Sep ; OK=1 ; fi
if expr $3 == 10 >;/dev/null ; then M=Oct ; OK=1 ; fi
if expr $3 == 11 >;/dev/null ; then M=Nov ; OK=1 ; fi
if expr $3 == 12 >;/dev/null ; then M=Dec ; OK=1 ; fi
if expr $3 == 1 >;/dev/null ; then M=Jan ; OK=1 ; fi
if expr $OK == 1 >; /dev/null ; then
ls -l --full-time $A 2>;/dev/null | grep "$M $4" | grep $2 ;
else
echo Usage: $0 path Year Month Day;
echo Example: $0 ~ 1998 6 30;
fi
如何计算当前目录下的文件数和目录数
[Copy to clipboard] [ - ] CODE:
# The right of usage, distribution and modification is here by granted by the author.
# The author deny any responsibilities and liabilities related to the code.
#
OK=0
A=`find $1 -print`
if expr $3 == 1 >;/dev/null ; then M=Jan ; OK=1 ; fi
if expr $3 == 2 >;/dev/null ; then M=Feb ; OK=1 ; fi
if expr $3 == 3 >;/dev/null ; then M=Mar ; OK=1 ; fi
if expr $3 == 4 >;/dev/null ; then M=Apr ; OK=1 ; fi
if expr $3 == 5 >;/dev/null ; then M=May ; OK=1 ; fi
if expr $3 == 6 >;/dev/null ; then M=Jun ; OK=1 ; fi
if expr $3 == 7 >;/dev/null ; then M=Jul ; OK=1 ; fi
if expr $3 == 8 >;/dev/null ; then M=Aug ; OK=1 ; fi
if expr $3 == 9 >;/dev/null ; then M=Sep ; OK=1 ; fi
if expr $3 == 10 >;/dev/null ; then M=Oct ; OK=1 ; fi
if expr $3 == 11 >;/dev/null ; then M=Nov ; OK=1 ; fi
if expr $3 == 12 >;/dev/null ; then M=Dec ; OK=1 ; fi
if expr $3 == 1 >;/dev/null ; then M=Jan ; OK=1 ; fi
if expr $OK == 1 >; /dev/null ; then
ls -l --full-time $A 2>;/dev/null | grep "$M $4" | grep $2 ;
else
echo Usage: $0 path Year Month Day;
echo Example: $0 ~ 1998 6 30;
fi
如何计算当前目录下的文件数和目录数
[Copy to clipboard] [ - ] CODE:
# ls -l * |grep "^-"|wc -l ---- to count files
# ls -l * |grep "^d"|wc -l ----- to count dir
如何只列子目录?
[Copy to clipboard] [ - ] CODE:
# ls -l * |grep "^d"|wc -l ----- to count dir
如何只列子目录?
[Copy to clipboard] [ - ] CODE:
ls -F | grep /$ 或者 alias sub = "ls -F | grep /$"(linux)
ls -l | grep "^d" 或者 ls -lL | grep "^d" (Solaris)
如何实现取出文件中特定的行内容
[Copy to clipboard] [ - ] CODE:
ls -l | grep "^d" 或者 ls -lL | grep "^d" (Solaris)
如何实现取出文件中特定的行内容
[Copy to clipboard] [ - ] CODE:
如果你只想看文件的前5行,可以使用head命令,
如: head -5 /etc/passwd
如果你想查看文件的后10行,可以使用tail命令,
如: tail -10 /etc/passwd
你知道怎么查看文件中间一段吗?你可以使用sed命令
如: sed -n '5,10p' /etc/passwd 这样你就可以只查看文件的第5行到第10行。
如何查找含特定字符串的文件
[Copy to clipboard] [ - ] CODE:
如: head -5 /etc/passwd
如果你想查看文件的后10行,可以使用tail命令,
如: tail -10 /etc/passwd
你知道怎么查看文件中间一段吗?你可以使用sed命令
如: sed -n '5,10p' /etc/passwd 这样你就可以只查看文件的第5行到第10行。
如何查找含特定字符串的文件
[Copy to clipboard] [ - ] CODE:
例如查找当前目录下含有"the string you want find..."字符串的文件:
$find . -type f -exec grep “the string you want find...” {} ; -print
如何列出目录树
[Copy to clipboard] [ - ] CODE:
$find . -type f -exec grep “the string you want find...” {} ; -print
如何列出目录树
[Copy to clipboard] [ - ] CODE:
下面的短小的shell程序可以列出目录树, 充分利用了sed强大的模式匹配能力.
目录树形式如下:
.
`----shellp
`----updates
`----wu-ftpd-2.4
| `----doc
| | `----examples
| `----src
| | `----config
| | `----makefiles
| `----support
| | `----makefiles
| | `----man
| `----util
脚本如下:
#!/bin/sh
# dtree: Usage: dtree [any directory]
dir=${1:-.}
(cd $dir; pwd)
find $dir -type d -print | sort -f | sed -e "s,^$1,," -e "/^$/d" -e "s,[^/]*/([^/]*)$,`----1," -e "s,[^/]*/,| ,g"
如何实现取出文件中特定的列内容
[Copy to clipboard] [ - ] CODE:
目录树形式如下:
.
`----shellp
`----updates
`----wu-ftpd-2.4
| `----doc
| | `----examples
| `----src
| | `----config
| | `----makefiles
| `----support
| | `----makefiles
| | `----man
| `----util
脚本如下:
#!/bin/sh
# dtree: Usage: dtree [any directory]
dir=${1:-.}
(cd $dir; pwd)
find $dir -type d -print | sort -f | sed -e "s,^$1,," -e "/^$/d" -e "s,[^/]*/([^/]*)$,`----1," -e "s,[^/]*/,| ,g"
如何实现取出文件中特定的列内容
[Copy to clipboard] [ - ] CODE:
我们经常会遇到需要取出分字段的文件的某些特定字段,例如/etc/password就是通过“:”分隔各个字段的。可以通过cut命令来实现。例如,我们希望将系统账号名保存到特定的文件,就可以:
cut -d: -f 1 /etc/passwd >; /tmp/users
-d用来定义分隔符,默认为tab键,-f表示需要取得哪个字段。
当然也可以通过cut取得文件中每行中特定的几个字符,例如:
cut -c3-5 /etc/passwd
就是输出/etc/passwd文件中每行的第三到第五个字符。
-c 和 -f 参数可以跟以下子参数:
N 第N个字符或字段
N- 从第一个字符或字段到文件结束
N-M 从第N个到第M个字符或字段
-M 从第一个到第N个字符或字段
在vim中实现批量加密
[Copy to clipboard] [ - ] CODE:
cut -d: -f 1 /etc/passwd >; /tmp/users
-d用来定义分隔符,默认为tab键,-f表示需要取得哪个字段。
当然也可以通过cut取得文件中每行中特定的几个字符,例如:
cut -c3-5 /etc/passwd
就是输出/etc/passwd文件中每行的第三到第五个字符。
-c 和 -f 参数可以跟以下子参数:
N 第N个字符或字段
N- 从第一个字符或字段到文件结束
N-M 从第N个到第M个字符或字段
-M 从第一个到第N个字符或字段
在vim中实现批量加密
[Copy to clipboard] [ - ] CODE:
密码中还是不能带空格,不管了,能加密就好,先这么用着。
============================================================
#!/bin/bash
# Encrypt file with vim
if (test $# -lt 2) then
echo Usage: decrypt password filename
else
vim -e -s -c ":set key=$1" -c ':wq' $2
echo "$2 encrypted."
fi
============================================================
[weeder@SMTH weeder]$ for file in *.txt ; do encrypt test $file ; done
test2.txt encrypted.
test4.txt encrypted.
test9.txt encrypted.
kick.txt encrypted.
echo "$2 encrypted."
fi
[weeder@SMTH weeder]$ for file in *.txt ; do encrypt test $file ; done
test2.txt encrypted.
test4.txt encrypted.
test9.txt encrypted.
kick.txt encrypted.
too_old.txt encrypted.
too_old_again.txt encrypted.
bg5.txt encrypted.
[weeder@SMTH weeder]$
$@等特定shell变量的含义
[Copy to clipboard] [ - ] CODE:
============================================================
#!/bin/bash
# Encrypt file with vim
if (test $# -lt 2) then
echo Usage: decrypt password filename
else
vim -e -s -c ":set key=$1" -c ':wq' $2
echo "$2 encrypted."
fi
============================================================
[weeder@SMTH weeder]$ for file in *.txt ; do encrypt test $file ; done
test2.txt encrypted.
test4.txt encrypted.
test9.txt encrypted.
kick.txt encrypted.
echo "$2 encrypted."
fi
[weeder@SMTH weeder]$ for file in *.txt ; do encrypt test $file ; done
test2.txt encrypted.
test4.txt encrypted.
test9.txt encrypted.
kick.txt encrypted.
too_old.txt encrypted.
too_old_again.txt encrypted.
bg5.txt encrypted.
[weeder@SMTH weeder]$
$@等特定shell变量的含义
[Copy to clipboard] [ - ] CODE:
在shell脚本的实际编写中,有一些特殊的变量十分有用:
$# 传递到脚本的参数个数
$* 以一个单字符串显示所有向脚本传递的参数。与位置变量不同,此选项参数可超过9个
$$ 脚本运行的当前进程ID号
$! 后台运行的最后一个进程的进程ID号
$@ 与$#相同,但是使用时加引号,并在引号中返回每个参数
$- 显示shell使用的当前选项,与set命令功能相同
$? 显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误。
如何使程序的执行结果同时定向到屏幕和文件
[Copy to clipboard] [ - ] CODE:
$# 传递到脚本的参数个数
$* 以一个单字符串显示所有向脚本传递的参数。与位置变量不同,此选项参数可超过9个
$$ 脚本运行的当前进程ID号
$! 后台运行的最后一个进程的进程ID号
$@ 与$#相同,但是使用时加引号,并在引号中返回每个参数
$- 显示shell使用的当前选项,与set命令功能相同
$? 显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误。
如何使程序的执行结果同时定向到屏幕和文件
[Copy to clipboard] [ - ] CODE:
program_name |tee logfile
这样程序执行期间的显示都记录到logfile同时显示到标准输出(屏幕)。
如何用sendmail给系统所有用户送信
[Copy to clipboard] [ - ] CODE:
这样程序执行期间的显示都记录到logfile同时显示到标准输出(屏幕)。
如何用sendmail给系统所有用户送信
[Copy to clipboard] [ - ] CODE:
首先在aliases文件里面建立一个alias:
alluser: :include:/etc/mail/allusers
并执行newaliases使之生效,然后在/etc/mail/allusers里面列出所有用户,可以使用下面的命令:
awk -F: '$3 >; 100 { print $1 }' /etc/passwd >; /etc/mail/allusers
如何查找某条命令的相关库文件
[Copy to clipboard] [ - ] CODE:
alluser: :include:/etc/mail/allusers
并执行newaliases使之生效,然后在/etc/mail/allusers里面列出所有用户,可以使用下面的命令:
awk -F: '$3 >; 100 { print $1 }' /etc/passwd >; /etc/mail/allusers
如何查找某条命令的相关库文件
[Copy to clipboard] [ - ] CODE:
在制作自己的发行版时经常需要判断某条命令需要哪些库文件的支持,以确保指定的命令在独立的系统内可以可靠的运行。
在Linux环境下通过ldd命令即可实现,在控制台执行:
ldd /bin/ls
即可得到/bin/ls命令的相关库文件列表。
如何使用host命令获得更多信息
[Copy to clipboard] [ - ] CODE:
在Linux环境下通过ldd命令即可实现,在控制台执行:
ldd /bin/ls
即可得到/bin/ls命令的相关库文件列表。
如何使用host命令获得更多信息
[Copy to clipboard] [ - ] CODE:
Host 能够用来查询域名,然而它可以得到更多的信息。host -t mx linux.com可以查询出Linux.com的MX记录,以及处理Mail的Host的名字。Host -l linux.com会返回所有注册在linux.com下的域名。host -a linux.com则会显示这个主机的所有域名信息。
如何停止终端多个进程
[Copy to clipboard] [ - ] CODE:
如何停止终端多个进程
[Copy to clipboard] [ - ] CODE:
以下是脚本:
echo "系统当前用户"
echo "---------------"
who | awk '{print $2}'
echo "---------------"
echo "输入要杀死终端的终端号:"
read $TTY
kill -9 ${K}=`ps -t $TTY | grep [0-9] | awk '{print $1}'`
常用脚本命令集
QUOTE: 如何列出目录树
代码:
下面的短小的shell程序可以列出目录树, 充分利用了sed强大的模式匹配能力.
目录树形式如下:
.
`----shellp
`----updates
`----wu-ftpd-2.4
| `----doc
| | `----examples
| `----src
| | `----config
| | `----makefiles
| `----support
| | `----makefiles
| | `----man
| `----util
脚本如下:
#!/bin/sh
# dtree: Usage: dtree [any directory]
dir=${1:-.}
(cd $dir; pwd)
find $dir -type d -print | sort -f | sed -e "s,^$1,," -e "/^$/d" -e "s,[^/]*/([^/]*)$,`----1," -e "s,[^/]*/,| ,g"
终于在Redhat 9.0下完成了这个shell,因为进入学习Linux不到一周,太费尽了,有点感想和总结,提出来大家批评指正.
1,变量dir是命令,改为dir1
2.提供一个sed的中文学习网址:
http://www-900.ibm.com/developerWorks/cn/linux/shell/sed/sed-1/index.shtml
http://www-900.ibm.com/developerWorks/cn/linux/shell/sed/sed-2/index.shtml
http://www-900.ibm.com/developerWorks/cn/linux/shell/sed/sed-3/index.shtml
3.完成后的代码如下:
QUOTE: #!/bin/sh
# dtree: Usage: dtree [any directory]
dir1=${1:-.}
(cd $dir1;pwd)
find $dir1 -type d -print | sort -f | sed -e"s,[^/]*/\([^/]*\)$,'--\1," -e 's,[^/]*/, |,g'
4.对sed命令的解释:
-e"s,[^/]*/\([^/]*\)$,'--\1,"
解释如下:
s表示替换;
s后的逗号表示分割,一般使用/来作为分割符号,,但是由于/表示路径,所以使用逗号;
[^/]*/\([^/]*\)$表示
第一个不是字符/([^/],
中间没有字符/(*),但是以字符/结束的最后的字符串,
并使用标记以方便使用\([^/]*\)$;
但是只替换第一个出现的字符串,没有出现g
'--\1 表示在标记1的地方进行替换
-e 's,[^/]*/, |,g'
解释如下:
[^/]*/ 表示第一个不是/([^/],中间没有/(*),但是以/结束的最后的字符串,
g 表示任何地方出现匹配的字符串都替换;
5.感觉Shell有点类似DOS下的bat文件.不知道对不对
6.为什么在redhat 9.0 下 统计文件有问题,必须去掉*
ls -l | grep "^-" |wc -l
ls -l | grep "^d" | wc -l
我想请问是这条命令本身就是错误还是由于版本的问题,类似当时的MSDOS 和PC DOS的问题,有些命令刚好相反.
请高手指正.
echo "系统当前用户"
echo "---------------"
who | awk '{print $2}'
echo "---------------"
echo "输入要杀死终端的终端号:"
read $TTY
kill -9 ${K}=`ps -t $TTY | grep [0-9] | awk '{print $1}'`
常用脚本命令集
QUOTE: 如何列出目录树
代码:
下面的短小的shell程序可以列出目录树, 充分利用了sed强大的模式匹配能力.
目录树形式如下:
.
`----shellp
`----updates
`----wu-ftpd-2.4
| `----doc
| | `----examples
| `----src
| | `----config
| | `----makefiles
| `----support
| | `----makefiles
| | `----man
| `----util
脚本如下:
#!/bin/sh
# dtree: Usage: dtree [any directory]
dir=${1:-.}
(cd $dir; pwd)
find $dir -type d -print | sort -f | sed -e "s,^$1,," -e "/^$/d" -e "s,[^/]*/([^/]*)$,`----1," -e "s,[^/]*/,| ,g"
终于在Redhat 9.0下完成了这个shell,因为进入学习Linux不到一周,太费尽了,有点感想和总结,提出来大家批评指正.
1,变量dir是命令,改为dir1
2.提供一个sed的中文学习网址:
http://www-900.ibm.com/developerWorks/cn/linux/shell/sed/sed-1/index.shtml
http://www-900.ibm.com/developerWorks/cn/linux/shell/sed/sed-2/index.shtml
http://www-900.ibm.com/developerWorks/cn/linux/shell/sed/sed-3/index.shtml
3.完成后的代码如下:
QUOTE: #!/bin/sh
# dtree: Usage: dtree [any directory]
dir1=${1:-.}
(cd $dir1;pwd)
find $dir1 -type d -print | sort -f | sed -e"s,[^/]*/\([^/]*\)$,'--\1," -e 's,[^/]*/, |,g'
4.对sed命令的解释:
-e"s,[^/]*/\([^/]*\)$,'--\1,"
解释如下:
s表示替换;
s后的逗号表示分割,一般使用/来作为分割符号,,但是由于/表示路径,所以使用逗号;
[^/]*/\([^/]*\)$表示
第一个不是字符/([^/],
中间没有字符/(*),但是以字符/结束的最后的字符串,
并使用标记以方便使用\([^/]*\)$;
但是只替换第一个出现的字符串,没有出现g
'--\1 表示在标记1的地方进行替换
-e 's,[^/]*/, |,g'
解释如下:
[^/]*/ 表示第一个不是/([^/],中间没有/(*),但是以/结束的最后的字符串,
g 表示任何地方出现匹配的字符串都替换;
5.感觉Shell有点类似DOS下的bat文件.不知道对不对
6.为什么在redhat 9.0 下 统计文件有问题,必须去掉*
ls -l | grep "^-" |wc -l
ls -l | grep "^d" | wc -l
我想请问是这条命令本身就是错误还是由于版本的问题,类似当时的MSDOS 和PC DOS的问题,有些命令刚好相反.
请高手指正.
相关阅读 更多 +