day05--文件管理之联网下载,文件上传,排序,去重截取

文件管理之:联网下载文件(wget,curl),文件上传与下载(rz,sz)

---------------------wget,curl联网下载文件-------------------

1.Centos-7系统最小化安装默认没有wget命令,需要进行安装

[root@oldboy--day01 ~]# yum install wget -y

2.找到需要下载下载的资源

  复制资源的链接地址

3.在Linux上使用wget命令进行下载(默认安装到当前目录来)

[root@oldboy--day01 ~]# wget http://fj.xuliangwei.com/public/weixin.py

4.由于我们下载的是文件,所以我们可以用cat less more 查看该文件

[root@oldboy--day01 ~]# cat weixin.py

5.使用wget下载资源时,指定保存的位置,并重命名

[root@oldboy--day01 ~]# wget -O /opt/tt.png http://fj.xuliangwei.com/public/ks.jpeg

6.下载资源时,如果不想重命名只想修改保存的的路径,请带上原有的名字

[root@oldboy--day01 ~]# wget -O /opt/ks.jpeg http://fj.xuliangwei.com/public/ks.jpeg


curl  浏览网络上的资源

1.在线浏览网站资源内容(源代码)

[root@oldboy--day01 ~]# curl  http://fj.xuliangwei.com/public/weixin.py

2.使用curl将内容保存到本地,并重命名(如果没有明确指定路径,则表示当前目录)

[root@oldboy--day01 ~]# curl -o weixin.txt http://fj.xuliangwei.com/public/weixin.py

3.将资源保存至指定路径

[root@oldboy--day01 ~]# curl -o /opt/weixin.py http://fj.xuliangwei.com/public/weixin.py

PS:通常情况下我们推荐使用wget下载,但由于系统有时候默认没有wget,偶尔会使用一下curl

练习:

1.wget保存至本地/etc/yum.repos.d/CentOS-Base.repo  http://mirrors.aliyun.com/repo/Centos-7.repo

[root@oldboy--day01 ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

2.curl保存至本地 /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo

[root@oldboy--day01 ~]# curl -o /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo

3.最后执行一条命令检查 yum makecache

----------------rz和sz  #上传和下载文件(Windows->Linux)------------------

   PS:如果无法将文件直接拖拽进Linux服务器

  1.要么没有安装lrzsz,建议安装 

      yum install lrzsz -y

  2.上传的文件是个空文件

     rz        #只能上传文件,不支持上传文件夹,不支持上传大于4G的文件,也不支持断点续传

     sz       #/path/file  #只能下载文件(任意单个文件),不支持下载文件夹

文件管理之:命令查找(which,whereis,find)

---------------命令查找-------------

1.查找一个命令的绝对路径

当我们想执行一个命令的绝对路径时,先使用which command 查询绝对路径

  which ls #查找ls命令的绝对路径

2.whereis也是用来查询命令的绝对路径,帮助手册,等

   whereis ls  //查找命令的路径,帮助手册.等

   whereis -b ls  //仅显示命令所在的路径

3.对于内核相关的一些命令,使用whichwhereis是无法查询到,需要使用type命令查询

  type -a ls  #查看命令的绝对路径(包括别名)

   对于后面使用一个命令的聚堆路径时.

文件管理之:字符处理命令(sort,unip,cut,sed,grep,awk,wc)

------------------------sort 排序---------------------

在有些情况下,需要对应一个无序的文本进行数据的排序,这时就需要使用sort进行排序了

sort [OPTION]...[FILE]...

 -r: 倒序 -n:按数字排序 -t: 指定分隔符(默认空格) -k: 指定第几列,指定几列几字符(指定1,1 3.1,3.3)

1.首先创建一个文件,写入一个无序的内容

b:3

c:2

a:4

e:5

d:1

f:11

-----------------------------------------------------------------------------------------------------------

[root@oldboy--day01 ~]# cat >>file.txt<<EOF

> b:3

> c:2

> a:4

> e:5

> d:1

> f:11

> EOF

2.使用sort下面对输出的内容进行排序

a:4

b:3

c:2

d:1

-------------------------------------------------------------------------------------------------------------

[root@oldboy--day01 ~]# sort file.txt

a:4

b:3

c:2

d:1

e:5

f:11

结果并不是按照数字排序,而是按字母排序

处理方法:可以使用-t指定分隔符,使用-k 指定需要排序的列

[root@oldboy--day01 ~]# sort -t ":" -k2 file.txt

d:1

f:11

c:2

b:3

a:4

e:5

可以看出并不是按照数字大小进行排序的而是以第二列的第一个字符大小进行排序的

如果想要按数字大小的方式 进行排序,需要会用参数 -name就可以使用unip命令解决这个问题

[root@oldboy--day01 ~]# sort -t ":"  -k2 file.txt -n

d:1

c:2

b:3

a:4

e:5

f:11

------------------------unip去重-----------------------------

如果文件中有许多行完全相同的内容,当前是希望能删除重复的行,同时还可以统计出完全想听的行的总数,

name就可以使用unip命令解决这个问题(但必须配合sort使用).

unip   [OPTION]...[INPUT [OUTPUT]]

 选项: -c 计算重复的行

 1.创建一个file1.txt文件:

abc

123

abc

123

----------------------------

[root@oldboy--day01 ~]# cat >>file1.txt<<EOF

> abc

> 123

> abc

> 123

> EOF

2.unip需要和sort一起使用,先使用sort排序,让重复内容连接到一起

123

123

abc

abc

-----------------

[root@oldboy--day01 ~]# sort file1.txt

123

123

abc

abc

3.使用uniq去除相邻重复的行

[root@oldboy--day01 ~]# sort file.txt |uniq

123

abc

4.-c参数能统计出文件中每行内容重复的次数

[root@oldboy--day01 ~]# sort file.txt |uniq -c

2 123

2 abc

---------------------------cut截取字段----------------

cut OPTION...[FILE]...

  选项:-d 指定分隔符 -f 数字,取第几列 -f3,6第三列和6列 -c 按字符取(空格也算)

   [root@oldboy--day01 ~]# cat >>file2.txt <<EOF

   Im xlw, is QQ 552408925

   EOF

实现: 筛选出文件里 xlw以及552408925

[root@oldboy--day01 ~]# awk '{print $2,$5}' file2.txt | awk -F "," '{print $1,$2}'

xlw 552408925

[root@oldboy--day01 ~]# cut -d " " -f 2,5 file2.txt | awk -F "," '{print $1,$2}'

xlw 552408925

[root@oldboy--day01 ~]# cut -d " " -f 2,5 file2.txt | sed 's#,##g'

xlw 552408925

[root@oldboy--day01 ~]# sed 's#,##g' file2.txt | awk '{print $2,$5}'

xlw 552408925

#PS: 实际生产使用过程中,很少使用到cut,通常都是使用awk,因为awk 是取列专业户

---------------------wc统计行号--------------------

wc [OPTION]... [FILE]...

选项:-l显示文件行数

1.wc -l /etc/fstab #统计/etc/fstab文件有多少行

2.wc -l /etc/services #统计/etc/services 文件行号

练习题: 过滤出/etc/passwd以nologin结尾的内容,并统计有多少行

1.先筛选出目标的行---筛选出/etc/passwd中以nologin结尾的行

[root@oldboy--day01 ~]# grep "nologin$" /etc/passwd 

 2.然后进行统计

[root@oldboy--day01 ~]# grep "nologin$" /etc/passwd | wc - l

18

 扩展统计文件行号的方法

[root@oldboy--day01 ~]# cat -n /etc/services | tail -1

[root@oldboy--day01 ~]# grep -n ".*" /etc/services | tail -1

1.习题: 分析如下日志,统计每个域名被访问的次数。

[root@oldboy--day01 tmp]# cat >> web.log <<EOF

http://www.xuliangwei.com/index.html

http://www.xuliangwei.com/1.html

http://post.xuliangwei.com/index.html

http://mp3.xuliangwei.com/index.html

http://www.xuliangwei.com/3.html

http://post.xuliangwei.com/2.html

EOF

[root@oldboy--day01 ~]# cut -d "/" -f 3 web.log | sort | uniq -c | sort -nr

[root@oldboy--day01 ~]# awk -F "/" '{print $3}' web.log |sort |uniq -c |sort -nr

习题: 使用awk取出系统的IP地址,

思路如下:

  1.我要取的值在哪里 ifconfig ens32

   2.如何缩小取值范围(行)

   3.如何精确具体内容(列)

先拿到结果,然后提取有关键字那一行,最后使用awk取出那一列

[root@oldboy--day01 ~]# ifconfig ens32|grep "netmask" | awk '{print $2}'

10.0.0.200

[root@oldboy--day01 ~]# ifconfig ens32 | awk '/netmask/' | awk '{print $2}'

10.0.0.200

[root@oldboy--day01 ~]# ifconfig ens32 | awk '/netmask/ {print $2}'

10.0.0.200

习题:分析如下日志,请提取出访问次数最高的TOP10IP地址

[root@oldboy--day01 ~]# awk '{print $1}' fj.xuliangwei.com.log |sort |uniq -c|sort -nr | head

习题: 将/etc/passwd文件中的第一行中的第一列和最后一列位置进行 交换。


习题: 将/etc/sysconfig/selinux 文件中的SELINUX=enforcing替换成 SELINUX=disabled

取列:cut awk()(推荐)

替换:sed

取行: grep awk

---------------------wc统计行号--------------------

统计文件总共有多少行

wc [OPTION]....[FILE]...

选项: -l显示文件行数 -c显示文件字节 -w显示文件单词

1.wc -l显示文件行数 -c显示文件字节 -w显示稳基建单词

2.wc -l/etc/fstab #统计/etc/fstab文件有多少行

3.wc -l /etc/services #统计/etc/services 文件行号

扩展方法

[root@oldboy--day01 ~]# grep -n ".*" /etc/services | tail -l

[root@oldboy--day01 ~]# awk '{print NR $0}' /etc/services | tail -l

[root@oldboy--day01 ~]# cat -n /etc/services | tail -l

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容