常见Linux命令总结(1)

这几天配置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 -lfile.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

 

你可能感兴趣的:(hadoop,linux,正则表达式,shell,bash,login)