Day4—文件管理
1、cp 复制
-v:详细显示命令的操作
-r:递归处理目录与子目录
-p:保留源文件或目录的属性
1.将当前目录下的file文件,复制到/tmp/目录下,并重新命名为file_copy
[root@oldboyedu ~]# cp file /tmp/file_copy
2.将file1复制到/tmp目录下
[root@oldboyedu ~]# cp file1 /tmp/
3.在拷贝过程中加上-p参数,保存文件原有的属性
[root@oldboyedu ~]# cp -p file /tmp/
4.如何拷贝一个文件夹,并且文件夹中有很多的子文件, -r递归复制 (文件夹===目录)
[root@oldboyedu ~]# cp /etc/ /tmp/ -r
5.拷贝不同路径下的不同文件至同一个目录下 -v是显示详细过程
[root@oldboyedu ~]# cp file1 /etc/hostname /etc/hosts /opt/ -v
6.拷贝不同路径下的不同文件+不同的目录 至同一个位置,怎么办?
[root@oldboyedu ~]# cp -rp file1 oldboy1/ file /etc/ /mnt/ /opt/
7.在复制过程中频繁触发重复复制,提示确认操作?
[root@oldboyedu ~]# \cp -r /etc/ /opt/
[root@oldboyedu ~]# /bin/cp -r /etc/ /opt/
8.扩展项
[root@oldboyedu ~]# cp {file5,file5-bak} -v
[root@oldboyedu ~]# cp /etc/sysconfig/network-scripts/{ifcfg-ens32,ifcfg-ens32-bak}
2、cat查看文件内容
-n :查看一个文件有多少行
-A :查看文件的特殊符号,比如文件中存在TAB键
cat扩展:创建一个文件,并写入内容
[root@oldboyedu ~]# cat >> test.txt <<EOF #EOF代表开始
test1
test2
test3
EOF
---less、more
less /etc/service :使用空格进行翻页,q退出
more /etc/service :使用空格进行翻页,q退出
---head
[root@oldboyedu ~]# head pass 查看头部内容,默认前十行
head -n5 pass 查看头部5行,使用-n指定
ps aux | head -5 了解
---tail
[root@oldboyedu ~]# tail pass 查看文件尾部默认十行
tail -20 /var/log/secure
tail -f /var/log/messages -f 查看文件尾部的变化
ps aux | tail -5
---grep过滤文件内容
1、过滤除pass文件中的root相关的行
[root@oldboyedu ~]# grep "root" pass
2、过滤pass文件中,匹配以root开头的
[root@oldboyedu ~]# grep "^root" pass
3、过滤pass文件中,匹配以bash结尾的行
[root@oldboyedu ~]# grep "bash$" pass
4、显示行号
[root@oldboyedu ~]# grep -n "bash$" pass
5.扩展了解
grep -n -A 2 "Failed" /var/log/secure #匹配/var/log/secure文件中Failed字符串,并打印它的下2行
grep -n -B 2 "Failed" /var/log/secure #匹配/var/log/secure文件中Failed字符串,并打印它的上2行
grep -n -C 2 "Failed" /var/log/secure #匹配/var/log/secure文件中Failed字符串
6.过滤出包含ftp的行
[root@oldboyedu ~]# grep "ftp" pass
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
7.过滤除了ftp的行,其他的全部显示
[root@oldboyedu ~]# grep -v "ftp" pass
8.忽略大小写方式
[root@oldboyedu ~]# grep -i "ftp" pass
9.过滤pass文件中以sync结尾的,或者ftp相关的行,打印出来.同时不区分大小写
[root@oldboyedu ~]#grep -Ei "sync$|ftp" pass
.代表任意单个字符 [a-z] [A-Z] [0-9]
*表示所有
.*代表所有的任意字符