先说道面试题
实例一:只查看test.txt文件(100行)内第20到第30行的内容(企业面试) 4 + 2种 方法
(1)seq 30 >/my/et.txt
head -30 /my/et.txt | tail -11
(2)sed -n '20,30' p et.txt (sed功能增删该查 -n 取消默认输出 按规则输出打印(p))
(3)awk ' NR>19&&NR<31' et.txt ({if(NR>=20 && NR<=30) print $1}可以替换 ‘’ 内的内容意思相同)
(4) grep
A 除了显示匹配到的一行外 ,并显示该行之后的num行 例子: grep 20 -A 10 a.txt
B 除了显示匹配到的一行外 ,并显示该行之前的num行 例子: grep 30 -B 10 a.txt
C 除了显示匹配到的一行外 ,并显示改行之前的num行 例子: grep 25 -C 5 a.txt
一条指令 将/my/a.txt 复制到 /temp/a.txt 后不提示信息
(1)\cp /my/a.txt /temp/a.txt
(2)/bin/cp /my/a.txt /temp/a.txt
(3)unalias cp ----> (该条功能不建议使用,服务器重启后 失效 )
cp /my/a.txt /temp/a.txt
把/my 目录及其子目录中使用扩展名为‘ .sh’结尾的文件中包含 oldboyde 字符串全部替换成 oldgirl;
创建测试数据
[root@root ~]# cd /my
[root@root my]# echo 'oldboy' >/test/a.sh
-bash: /test/a.sh: No such file or directory
[root@root my]# echo 'oldboy' >test/a.sh
[root@root my]# echo 'oldboy' >test.sh
[root@root my]# echo 'oldboy' >t.sh
[root@root my]# tree
.
├── 8.txt
├── ett.txt
├── new1
│ └── new2
│ └── new3
├── new2
│ └── new2
│ └── new3
├── test
│ └── a.sh
├── test.sh
└── t.sh
测试开始替换数据
[root@root my]#find -type f -name '*.sh'|xargs sed 's#oldboy#oldgirl#g' (只是替换但尚未修改)
oldgirl
oldgirl
oldgirl
[root@root my]# find -type f -name '*.sh'|xargs sed -i 's#oldboy#oldgirl#g'
(加 -i 直接替换修改)
[root@root my]#find -type f -name '*.sh'|xargs cat 信息流 给cat
oldgirl
oldgirl
oldgirl
(不加xargs 直接变成数据流 交给cat)
[root@root ~]# find /my -type f -name '*.sh'| cat
/my/test/a.sh
/my/t.sh
/my/test.sh
五星级别的命令 :
linux 三剑客之
grep \ awk \ sed;他们都有过滤字符串的功能;
grep :查找过滤最擅长
awk :处理列擅长(NF :代表字段 NR:代表 记录 一个记录代表一行)
sed : 擅长添加、替换、修改、删除 、
帮助指令:
ifconfig 查看网卡链接信息---- 相同于 ip addr
man 命令 Linux 指令
--help 简洁 版 帮助
help 命令 内置指令帮助
操作查看目录指令:
mkdir 创建目录
全名称:make directorys :
mkdir (/data)是创建的目录;或者 cd /; mkdir data
第一个指令 是 直接创建 目录 在根 " / "下 : mkdir /data ;
第二个是 进入根" / "下直接创建 :cd /; mkdir data
例子: mkdir /myfile 或者 cd /; mkdir myfile
#### 递归创建目录
mkdir -p /my/new1/new2
#### 多重创建
[root@root ~]# mkdir /yyn/{335,336,3365}/yyn -p
[root@root ~]# tree /yyn
/yyn
├── 332
│ └── yyn
├── 335
│ └── yyn
├── 336
│ └── yyn
└── 3365
└── yyn
ls 列表
ll :查看该目录下的文件总个数
指令规则:命令 【参数选项】【文件或路径】
ls -ld (参数 l 和 d) 多参数可以直接连起来操作 前面 加 “ - ”
参数 l (long) 长格式
参数 d (directorys) 查看目录
例子: ls -l \ ls -d \ ls -ld() ls /data (进入目录下查看)
cd 改变目录路径
全名称 :change directory
相当路径:没有从根 " / " 开始 cd data
绝对路径:从根 " / " 开始 cd /etc
例子: cd /etc ; cd data
pwd 打印工作目录(显示当前所在路径)
全名称 :print work directory
例子: pwd 输出结果:/directory / (那个文件)
touch 创建文件及更新时间戳
若文件不存在 touch file.txt
若文件存在 更新时间戳(文件的时间属性) ;
例子: touch /myfile/file.txt
touch 另外
touch {1..10}.txt 创建
mv `find /my -type f -name " *.txt " ` /data
vi 编辑文件
vi file.txt
vi 后跟 操作的文件 ; 回车进入待编辑状态
按 " a "或 " i " 字母 进入编辑状态 ; 编辑好之后
按 键盘 Esc 回到 待编辑状态;
输入 " :wq " 保存和退出 编辑 回到 命令行模式;
不想保存: 输入 :q
强制退出 输入 :q!
解释 wq : w(write) 、q (Quit) ;
vim 复杂编辑器
功能复杂,高亮,自动缩进,写脚本(shell / python 脚本用)
vim file.txt
按 " a "或 " i " 字母 进入编辑状态 ; 编辑好之后
按 键盘 Esc 回到 待编辑状态;
输入 " :w " 保存后再按":q"退出 编辑 回到 命令行模式;
echo 覆盖或追加内容 配合 " 重定向 > " , " 追加 >>"
echo ' I am study Linux now; ' >myfile.txt
echo {a..z} myfile.txt 相当于 序列 seq 部分功能
解释:echo 后面跟 文件内容 " > " 代表重定向到 那个文件
或者其他" > " 后的文件若存在 会 先清空 该文件的内容
后 写入 " > " 前面的 内容 ;
此 " > " 指令 操作 危险 ,在操作前 请先备份 ,
再操作;若想追加 则用 " >> "
例子: echo 'I drop in love river with you; '>>myfile.txt
cat 查找,单行和多行文本添加
Linux 常用的指令功能:
查看网卡连接设置
cat /etc/sysconfig/network-scripts/ifcfg- ens34 网卡名称
cat >myfile.txt 回车 后编辑输入 I love you in my life;在按 Ctrl + C 或 D 结束编辑;
[root@root myfile]# cat >>myfile.txt<> /my/a.txt << my
123
123
456
my
特殊符号 < 、< <、>、>> 的说明:箭头的指向代表数据的流向
'>' 或 (0\1\2)> 输出重定向:把前面的内容输入到后面,会清除原有的文件内容;(有 1 没有都一样)
例子 :>myfile.txt (清空原有内容) echo ' i love you ' >myfile.txt
'>>' 或 (0\1\2)>> 追加输出重定向:把前面的内容追加到后面,不会清除原有文件内容;
例子:echo 'I drop in love river with you; '>>myfile.txt
0< 或 < 输入重定向 : 把文件或文本内容 输入给 前面的命令;
例子:
[root@root myfile]# echo ' 1 2 3 4 '>myfile.txt
[root@root myfile]# cat myfile.txt
1 2 3 4
[root@root myfile]# xargs -n 2 >myfile.txt< 或 1>> ,数据(正确的数据)流向从左到右
例子: echo oldbook >myfile.txt echo oldbooks >> myfile.txt
标准错误输出( stderr ): 代码为2 ,使用 2> 或 2>> ,数据(错误的数据)流向从左到右
echo oldbook > myfile.text 2>b.txt 意思是:正确的数据输出到 myfile.txt,错误的输出到b.txt
cho odkbb > a.txt 2>'&' 意思是: 正确或者错误都输出到 a.txt
cho oooddd &>a.txt 意思是: 正确或者错误都输出到 a.txt
echo shuikm &>>a.txt 意思是:正确或者错误输出追加到 a.txt
xargs 分组
xargs -n number a.txt
例子:xargs -n 3
cp 拷贝
cp file /temp 把某个文件或目录拷贝到 某个地方
例子: cp a.txt /temp/ 相对路径拷贝
[root@root myfile]# cp /myfile/a.txt /my
cp: overwrite `/my/a.txt'? y
若拷贝目录需要 加参数 " -r 递归拷贝 "
" -a 相对于 ;
-p: 保持属性 ;
-d:链接文件
-r "拷贝目录
在拷贝时 ,让系统 不提示覆盖信息
cp 前 加 " \ " ;或者 写全路径
例子:/bin/cp /my/a.txt /temp/ a.txt
\cp -r /myfile /temp
rm remove
rm -f(force)强制 -r(recuresive) 递归删除目录 / mydirectory
rm -fr /{1,2,3,4,5,6,7,8}
mv 移动文件和目录
mv file.txt /temp 原位置文件就没有了
find 查找
find 查找 -type f (什么类型) -name (叫什么名字) " file.txt" -exec(做什么动作)
find /myfile -type f -name ' myfile.txt ' -exec rm {} \;
! 取反的意思 find /myfile -type f ! -name ' myfile.txt'
-a(and) 交集 find /myfile -type f -name ' myfile.txt' -a 'a.txt' 默认是交集
-o (or) 并集 find /myfile -type f -name ' myfile.txt' -o 'a.txt'
上面例子是:找到/myfile 目录下file类型的myfile.txt 文件 ' {} 内容 '删除操作
find /myfile -type f -name "*.txt " | xargs rm -f
把查找的内容 放到一行上 进行删除
find + rm 删除该目录下其他文件 但保留指定文件
find /my -type f !- name ' 8.txt' -exec rm -f {} \;
grep 过滤 -v 排除后面的
grep 【内容】 【 文件】 显示【内容】 例子:grep 123 a.txt
v 过滤排除的内容显示除了过滤以外的内容 例子: grep -v 123 a.txt
A 除了显示匹配到的一行外 ,并显示该行之后的num行 例子: grep 20 -A 10 a.txt
B 除了显示匹配到的一行外 ,并显示该行之前的num行 例子: grep 30 -B 10 a.txt
C 除了显示匹配到的一行外 ,并显示改行之前后的num行 例子: grep 25 -C 5 a.txt
head 头部 tail 尾部
head -num a.txt 读取前 num 行 从a.txt文件
例子:head -10 a.txt 读取前10行数据
tail -num a.txt 读取后 num 行 从a.txt文件
例子: tail -10 a.txt 读取后10行数据
有个 a.txt 文件内容100行,要求读取20-30行
例子:head -30 a.txt | tail -11
安装软件包
yum install 【参数】【y/n 代表 是否提示】
yum install tree -y
别名 的作用:alias \ unalias
给危险指令加防护 防止误操作
简化命令
alias 查看和设置系统现有的别名设置别名
unalias 取消现有的别名
unalias cp 取消cp -i 的别名
[root@root /]# alias rm='echo this command does not allow to use'
[root@root /]# rm
this command does not allow to use
[root@root /]# alias net='cat /etc/sysconfig/network-scripts/ifcfg-eth0'
[root@root /]# net
DEVICE=eth0
HWADDR=00:0c:29:54:22:9d
TYPE=Ethernet
UUID=f0212429-d0c9-4ff5-9d33-8c7231d5664c
ONBOOT=yes
NM_CONTROLLED=yes
BOOTPROTO=dhcp
USERCTL=no
PEERDNS=yes
IPV6INIT=no
seq 序列
seq num 默认从1开始num结束
seq -s " " num 横着从1开始num结束; -s 指定分隔符 默认 \n
seq num1 num2 从num1开始到num2结束
seq num1 num2 num3 从 num1 开始到 num3 结束 间隔 num2
横着输出打印
[root@root ~]# seq -s " " 10
1 2 3 4 5 6 7 8 9 10
[root@root my]# seq 10 |xargs -n 3
(seq num 默认从1开始num结束,xargs -n num 分组)
1 2 3
4 5 6
7 8 9
10
[root@root my]# seq 3 10 |xargs -n 3
(seq num1 num2 从num1开始到num2结束,xargs -n num 分组)
3 4 5
6 7 8
9 10
[root@root my]# seq 1 2 20 |xargs -n 3
(seq num1 num2 num3 从 num1 开始到 num3 结束 间隔 num2,xargs -n num 分组)
1 3 5
7 9 11
13 15 17
19
sed
语法:
sed ' s#1#2#g' et.txt
1 , 2 把 1 的内容, 替换成 2 的内容
# 号 是分隔符 ,可以 / 或者 @ 替换
参数:
-n 取消默认输出
sed -n '20,30'p /my/ett.txt
-i 修改文件内容
sed -i 's#oldboy#oldgirl#g' test.sh t.sh test/a.sh
-e 允许多项修改
功能:
p 打印
sed -n '20,30'p /my/ett.txt
g 和 s 联合是 表示当前行全局匹配替换
sed -i 's#oldboy#oldgirl#g' test.sh t.sh test/a.sh 原理是这样)
(1) sed -i 's#oldboy#oldgirl#g' `find /my -type f -name "*.sh"`
(2) find /my -type f -name "*.sh |xargs sed -i 's#oldboy#oldgirl#g'
s 查找并替换
sed -i 's#oldboy#oldgirl#g' test.sh t.sh test/a.sh (原理是这样)
(1) sed -i 's#oldboy#oldgirl#g' `find /my -type f -name "*.sh"`
(2) find /my -type f -name "*.sh |xargs sed -i 's#oldboy#oldgirl#g'