咋日回顾
命令 cp grep cat less more head tail tailf
1.cp拷贝文件
-p 保持源文件属性
-v 显示cp执行过程
-r 递归复制,通常用来复制目录
2.grep 文件过滤
-n 显示行号
-E 同事筛选多个目标
-A
-B
-C
-i 忽略大小写
-v 取反
^ 匹配关键字,以什么开头
$ 匹配关键字,以什么结尾
. 任意单个字符 【a-z】【A-Z】【0-9】
* 表示所有
.* 表示任意字符
^$ 表示空格
3.cat 查看文件内容
-n 显示行号
-A 查看文件特殊符号
4.less #查看大文件 空格翻页,上下移动键翻行 q 退出 ctrl+f 上翻 ctrl+b 下翻
more #查看大文件百分比 空格翻页,回车上下移动 q 退出 ctrl+f 上翻 ctrl+b 下翻
5.head 查看文件头部内容,默认前10行
-n 指定查看前几行
6.tail 查看文件尾部
-n 指定查看文件尾部后几行
-f |tailf 查看文件尾部实时变化
今日部分
文件的下载 wget curl
文件的上传下载 rz sz #不支持拷贝文件夹
文件内容进行排序 sort ,去重 uniq ,统计 wc
文件的截取 cut awk sed ...|
3.文件管理之:联网下载文件(wget 、curl) 文件上传下载(rz sz)
wget curl 联网下载
#1.centos7 系统最小化安装默认没有wget 命令 需要进行安装
[root@caoweiqiang ~]# yum install wget -y
#2.找到我们需要下载的源码
复制资源的连接地址------>
#3.在Linux上使用wget命令进行下载(默认下载到当前目录来,不知道当前目录就用pwd查看)
[root@caoweiqiang ~]# wget http://fj.xuliangwei.com/public/weixin.py
#4.由于我们下载的是文件,所以我们可以使用 cat less more 查看该文件
[root@caoweiqiang ~]# cat weixin.py
#5.使用wget 下载资源时,指定保存的位置,并重新命名
[root@caoweiqiang ~]# wget -O /opt/tt.png http://fj.xuliangwei.com/public/ks.jpeg
#6.下载资源时,如果不想重命名只想修改保存的路径,请带上源有的名称
[root@caoweiqiang ~]# wget -O/opt/ks.jpeg http://fj.xuliangwei.com/public/ks.jpeg
curl ------浏览网页上的资源(源代码)
#1.在线浏览网站资源内容(源代码)
[root@caoweiqiang ~]# curl http://fj.xuliangwei.com/public/weixin.py
#2.使用Ctrl 将内容保存到本地,并重命名(如果没有明确指定路径,则表示当前目录)
[root@caoweiqiang ~]# curl -o wei.txt http://fj.xuliangwei.com/public/weixin.py
#3.将资源保存到指定的路径
[root@caoweiqiang ~]# curl -o /opt/weixin.py http://fj.xuliangwei.com/public/weixin.py
PS:通常情况下推荐使用wget
rz sz ----上传下载
如果无法将文件直接拖拽进Linux服务器
#1.要么没有安装lrzsz ,建议安装 yum install lrzsz -y
#2.你上传的是一个空文件
#rz #只能上传文件,不支持上传文件夹,不支持上传大于4G文件,也不支持断点续传
#sz /path/file #只能下载文件 (任意单个文件),不支持下载文件夹
4.文件管理之:文件或命令查找(which whereis find)
#1.查找一个命令的绝对路径
#当我们想执行一个命令的绝对路径时,先使用which查看绝对路径
# which ls #查找ls命令的绝对路径
#2.whereis 也使用来查询命令的绝对路径
#whereis ls //查找命令的路径,帮助手册等
#whereis -b ls //仅显示命令的所在路径
#3.对于内核相关的一些命令,使用which whereis无法查询到时,需要用type命令查询
#type -a ls #查看路径的绝对路径*(包括全名)
5.文件管理之:文件内容处理命令(sort uniq cut sed awk wc )
sort 排序
sort # -r :倒序 -n :按数字排序 -t:指定分隔符(默认空格)-k指定第几列,指定几列几字符(指定1,1 3.1,3.3)
#1.创建一个文件,写入一些无需文件内容
[root@caoweiqiang ~]# cat >> file.txt <<EOF
> b:3
> c:2
> a:4
> e:5
> d:1
> f:11
> EOF
#2.使用sort下面对输出的内容进行排序
[root@caoweiqiang ~]# sort file.txt
a:4
b:3
c:2
d:1
e:5
f:11
#结构并不是按照数字排序,而是按字母排序
#可以用-t指定分隔符,使用-k指定需要排序的列
[root@caoweiqiang ~]# sort -t ":" -k2 file.txt
d:1
f:11 #第二行为什么是11? 需要按数字顺序排序,需家参数-n
c:2
b:3
a:4
e:5
#如果要按照数字顺序排序,需家参数-n
[root@caoweiqiang ~]# sort -t ":" -k2 -n file.txt
d:1
c:2
b:3
a:4
e:5
f:11
unit取重 选项: -c 计算重复的行
#1.创建一个file.txt文件
[root@caoweiqiang ~]# cat >> file.txt <<EOF
> abc
> 123
> abc
> 123
> abc
> EOF
#2.uniq需要和sort一起使用,先使用sort排序,让重复内容连续在一起
[root@caoweiqiang ~]# sort file.txt
123
123
abc
abc
abc
#3.使用uniq去处相邻重复的行 用-c参数能统计出文件中每行内容重复的次数
[root@caoweiqiang ~]# sort file.txt |uniq -c
2 123
3 abc
cut 截取字段
选项 -d 指定分隔符 -f 数字,取第几列 -f3,6 三列和六列 -c 按字符取(空格也算)
[root@caoweiqiang ~]# cat file2.txt
Im xlw, is QQ 552408925
#实现:筛选出文件里 xlw 552408925
[root@caoweiqiang ~]# cat file2.txt
Im xlw, is QQ 552408925
[root@caoweiqiang ~]# cut -d " " -f 2,5 file2.txt
xlw, 552408925
第一种方法
[root@caoweiqiang ~]# cut -d " " -f 2,5 file2.txt | awk -F "," '{print$1$2}'
xlw 552408925
[root@caoweiqiang ~]# cut -d " " -f 2,5 file2.txt | awk -F "," '{print$1,$2}'
xlw 552408925
第二种方法
[root@caoweiqiang ~]# cat file2.txt
Im xlw, is QQ 552408925
[root@caoweiqiang ~]# awk '{print$2,$5}' file2.txt
xlw, 552408925
[root@caoweiqiang ~]# awk '{print$2,$5}' file2.txt|awk -F "," '{print$1,$2}'
xlw 552408925
第三种方法
[root@caoweiqiang ~]# cat file2.txt
Im xlw, is QQ 552408925
[root@caoweiqiang ~]# cut -d " " -f 2,5 file2.txt
xlw, 552408925
[root@caoweiqiang ~]# cut -d " " -f 2,5 file2.txt |sed 's#,##g'
xlw 552408925
第四种方法
[root@caoweiqiang ~]# cat file2.txt
Im xlw, is QQ 552408925
[root@caoweiqiang ~]# sed 's#,##g' file2.txt |awk '{print$2,$5}'
xlw 552408925
wc统计行号
wc 选项:-l 显示文件行数
# wc -l /etc/fstab #统计 /etc/fstab文件有多少行
# wc -l /etc/services #统计/etc/services文件有多少行