这几天配置hadoop的过程中,顺便把几乎快忘光的Linux命令复习了一遍。现在总结总结。
一、一些简单的命令:
read var: 提示用户输入,并将输入赋值给变量
sort file.txt: 对file.txt文件中的行进行排序
uniq: 删除文本文件中出现的行列比如: sortfile.txt | uniq
grep 'pattern' file: 在文件内搜索字符串比如:grep'searchstring' file.txt
sed: Sed是一个基本的查找替换程序。可以从标准输入(比如命令管道)读入文本,并将
结果输出到标准输出(屏幕)。该命令采用正则表达式(见参考)进行搜索。
不要和shell中的通配符相混淆。比如:将linuxfocus 替换为
LinuxFocus :cat text.file | sed's/linuxfocus/LinuxFocus/' > newtext.file
awk: awk 用来从文本文件中提取字段。缺省地,字段分割符是空格,可以使用-F指定其他分割符。
cat file.txt | awk -F, '{print $1"," $3 }'这里我们使用,作为字段分割符,同时打印第一个和第三个字段。如果该文件内容如下: Adam Bor, 34, IndiaKerry Miller, 22, USA
命令输出结果为:Adam Bor, IndiaKerry Miller, USA
管道 (|) 将一个命令的输出作为另外一个命令的输入。
例如grep "hello" file.txt | wc -l在file.txt中搜索包含有”hello”的行并计算其行数。在这里grep命令的输出作为wc命令的输入。当然您可以使用多个命令。
重定向:将命令的结果输出到文件,而不是标准输出(屏幕)。> 写入文件并覆盖旧文件
>> 加到文件的尾部,保留旧文件内容。
二、注意
1. 变量常量混合的打印
例1.1变量常量混合的打印
num=2
echo "this is the ${num}nd"
例1.2变量常量混合的打印
num=2
echo "this is the $num"
echo "nd"
2. if流程操作
#!/bin/sh
程序必须以上面的行开始(必须方在文件的第一行)。符号#!用来告诉系统它后面的参数是用来执行该文件的程序。
if [ "$SHELL" ="/bin/bash" ]; then
echo "your login shell is the bash (bourne again shell)"
else
echo "your login shell is not bash but $SHELL"
fi