2010年12月4日土曜日

linux shell 笔记一

开头
#!/bin/sh

符号#!用来告诉系统它后面的参数是用来执行该文件的程序。在这个例子中我们使用/bin/sh来执行程序。
当编辑好脚本时,如果要执行该脚本,还必须使其可执行。
要使脚本可执行:
编译 chmod +x filename 这样才能用./filename 来运行

2 变量
#对变量赋值:
a="hello world"

2.1 环境变量
由export关键字处理过的变量叫做环境变量。

2.3 系统变量
$1,$2
$*
1> 正常输出
2> 错误输出
&  后台执行
/dev/null


2.4 常用系统变量
$n $1 表示第一个参数,$2 表示第二个参数 ...
$# 命令行参数的个数
$0 当前程序的名称
$? 前一个命令或函数的返回码
$* 以"参数1 参数2 ... " 形式保存所有参数
$@ 以"参数1" "参数2" ... 形式保存所有参数
$$ 本程序的(进程ID号)PID
$! 上一个命令的PID



Unix 命令
虽然在shell脚本中可以使用任意的unix命令,但是还是由一些相对更常用的命令。这些命令通常是用来进行文件和文字操作的。


cut -b colnum file: 指定欲显示的文件内容范围,并将它们输出到标准输出设备。比如:输出每行第5个到第9个字符cut -b5-9 file.txt


file somefile: 得到文件类型

read var: 提示用户输入,并将输入赋值给变量

sort file.txt: 对file.txt文件中的行进行排序

uniq: 删除文本文件中出现的行列比如:
sort file.txt | uniq

expr: 进行数学运算Example:
add 2 and 3expr 2 "+" 3

find: 搜索文件比如:根据文件名搜索
find . -name filename -print

tee: 将数据输出到标准输出设备(屏幕) 和文件比如:
somecommand | tee outfile

basename file: 返回不包含路径的文件名比如:
basename /bin/tux将返回 tux

dirname file: 返回文件所在路径比如:
dirname /bin/tux将返回 /bin

head file: 打印文本文件开头几行

tail file : 打印文本文件末尾几行

sed: Sed是一个基本的查找替换程序。可以从标准输入(比如命令管道)读入文本,并将结果输出到标准输出(屏幕)。该命令采用正则表达式(见参考)进行搜索。

awk: awk 用来从文本文件中提取字段。缺省地,字段分割符是空格,可以使用-F指定其他分割符。
cat file.txt | awk -F, '{print $1 "," $3 }'
这里我们使用,作为字段分割符,同时打印第一个和第三个字段。

管道
管道 (|) 将一个命令的输出作为另外一个命令的输入。
grep "hello" file.txt | wc -l   在file.txt中搜索包含有”hello”的行并计算其行数。

重定向
将命令的结果输出到文件,而不是标准输出(屏幕)。
> 写入文件并覆盖旧文件
>> 加到文件的尾部,保留旧文件内容。

反短斜线
用来查找过去24小时(-mtime –2则表示过去48小时)内修改过的文件。如果想将所有查找到的文件打一个包,则可以使用以下脚本:
tar -zcvf lastmod.tar.gz `find . -mtime -1 -type f -print`

0 件のコメント:

コメントを投稿