2019-7-29第四天

今天学习了文件管理的几个指令
第一个是cp,复制。
具体用法1.
将当前目录下的文件复制并重命名
如:将当前目录下的file文件,复制到/tmp/目录下,并重新命名为
file_copy
[root@oldboyedu ~]# cp file /tmp/file_copy
[root@oldboyedu ~]# ls /tmp/file_copy
/tmp/file_copy

将文件复制到某目录下
如:.将file1复制到/tmp目录下,
[root@oldboyedu ~]# cp file1 /tmp/
[root@oldboyedu ~]# cp file1 /tmp/file1 #这种很少使用

如何在拷贝文件的过程中。保持文件原有的属性不发生改变
具体例子如下:
-rw-r- r- . 1 root root 0 Jul 29 10:07 file

第一次修改

-rwxrwxrwx. 1 root root 0 Jul 29 10:03 file

第二次修改

-rwxrwxrwx. 1 adm adm 0 Jul 29 10:03 file

在拷贝的过程中,文件权限和身份都发生变化了

[root@oldboyedu ~]# cp file /tmp/
[root@oldboyedu ~]# ll /tmp/file
-rw-r- r- . 1 root root 0 Jul 29 10:11 /tmp/file

在拷贝过程中加上-p参数,保存文件原有的属性

[root@oldboyedu ~]# cp -p file /tmp/
[root@oldboyedu ~]# ll /tmp/file
-rwxrwxrwx. 1 adm adm 0 Jul 29 10:03 /tmp/file

如何复制一个文件夹及其中包含的子文件
用-r递归复制
用-v老来显示复制的详细过程
5
如何复制多个文件到同一个位置
如下:[root@oldboyedu ~]# cp -rp file1 oldboy1/ file /etc/
/mnt/ /opt/
[root@oldboyedu ~]# ls /opt/
etc file file1 mnt oldboy1
6如何克服在复制过程中频繁触发重复复制
如下:
[root@oldboyedu ~]# \cp -r /etc/ /opt/
[root@oldboyedu ~]# /bin/cp -r /etc/ /opt/

[root@oldboyedu ~]# cp {file5,file5-bak} -v
‘file5’ -> ‘file5-bak’
[root@oldboyedu ~]# cp /etc/sysconfig/networkscripts/{ifcfg-ens32,ifcfg-ens32-bak}
复制file5并改名为file—bak(备份使用)

第二个是cat 用来查看文件内容
具体用法:
[root@oldboyedu ~]# cp /etc/passwd ./pass
[root@oldboyedu ~]# cat pass #查看文件的所有内容,从
头到尾
[root@oldboyedu ~]# cat -n pass #查看一个文件有多少行
-n
[root@oldboyedu ~]# cat -A pass ##查看文件的特殊符号,
比如文件中存在tab键
cat还有扩展使用,创建一个文件并写入内容:
[root@oldboyedu ~]# cat >> test.txt <<EOF #EOF代表开

test1
test2
test3
EOF #EOF 代表结束
[root@oldboyedu ~]# cat test.txt
test1
test2
test3
第三组 less、more
less /etc/services #使用光标上下翻动,空格进行翻页,q退

more /etc/services #使用回车上下翻动,空格进行翻页,q退


第四组head tail

------head

[root@oldboyedu ~]# head pass #查看头部内容,默认前十行
[root@oldboyedu ~]# head -n5 pass #查看头部5行,使用-n指定

------tail

tail pass #查看文件尾部默认十行

[root@oldboyedu ~]# tail -20 /var/log/secure
[root@oldboyedu ~]# tail -f /var/log/messages #-f查看文
件尾部的变化
[root@oldboyedu ~]# tailf /var/log/messages #查看文件
尾部的变化
第5个grep过滤文件内容
如:#1. 过滤出pass文件中的root相关的行
[root@oldboyedu ~]# grep "root" pass
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin

2.过滤pass文件中,匹配以root开头的行

[root@oldboyedu ~]# grep "^root" pass
root:x:0:0:root:/root:/bin/bash

3.过滤pass文件中,匹配以bash结尾的行

[root@oldboyedu ~]# grep "bash$" pass
root:x:0:0:root:/root:/bin/bash
jack:x:1000:1000::/home/jack:/bin/bash

4.显示行号

[root@oldboyedu ~]# grep -n "bash$" pass
1:root:x:0:0:root:/root:/bin/bash
23:jack:x:1000:1000::/home/jack:/bin/bash

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.忽略大小写方式

2 今日总结

1.文件命令
cp
cat
[root@oldboyedu ~]# grep -i "ftp" pass
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin

9.过滤pass文件中以sync结尾的,或者ftp相关的行,打印出来.同时不

区分大小写

grep -Ei "sync$|ftp" pass

grep筛选的目标,会将整行打印出来.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容