接着上一章节,我们这一章接着讲指令,话不多说我们接着开始~~
语法: more [选项][文件]
功能: more命令,功能类似 cat
常用选项:
-n 对输出的所有行编号
q 退出more
重定向
>
和>>
echo "hello Linux" > log.txt
> log.txt
>
后面的文件名字cat
打印一下这个文件,就会发现,刚刚应该打印到屏幕上的就写入到了文件里~~那我们是不是可以去掉前面的这个
echo
?
>hello.txt
linux有一个设计理念,就是一些皆文件
对于任何文件来讲,读和写文件
显示器设备->显示器文件->向显示器打印,向显示器文件进行写入
对于上面的>
就是输出重定向,本来应该写入到显示器文件的,但是通过了>
就输出到了普通文件当中
那我们再次输入字符串到这个文件,内容是追加还是删除原本内容再添加文件呢?
我们来试一下
可以看到,每次重定向一次字符串就会修改里面的内容,是会先删除原来的内容,然后再进行新的字符串写入
最后一次操作是将一个空的字符输入到了文件,但是文件里还是有一个换行的,还是有大小的
我们再一次用>
创建一个文件,但是这个文件是没有大小的~~
所以得出结论,
>
输出重定向就是从0开始写文件,换而言之,就是会删除原来的字符串,再进行新的字符串写入
echo "hello linux" >> log.txt
>>
是追加重定向,就是不会删除原有的文件,继续往后添加数据这里的一个
>
符号就相当于C语言中的文件操作以w
方式写,每次写的时候都会清空文件
这里的一个>>
符号就相当于C语言中的文件操作以a
方式写,每次写的时候不会清空文件,直接往后面写入数据
就比如这里的cat
命令,就是默认写入到显示器文件当中~~
cat
ctrl + z
就退出了<
cat < log.txt
这里的<
是输入重定向的意思
cat命令本来应该从键盘上读数据,但是这个输入重定向从文本读数据到显示器上了
小结一下:
command > filename #输出重定向
command >> filename #追加重定向
command < filename #输入重定向
ll /dev/pts/
echo "hello linux" > /dev/pts/1
语法:
less [参数] 文件
功能:
less与more类似,但使用less可以随意浏览文件,而more仅能向前移动,却不能向后移动,而且less在查看之前不会加载整个文件。
选项:
-i 忽略搜索时的大小写
-N 显示每行的行号
/字符串:向下搜索“字符串”的功能
?字符串:向上搜索“字符串”的功能
n:重复前一个搜索(与 / 或 ? 有关)
N:反向重复前一个搜索(与 / 或 ? 有关)
q:quit
i=1;while [ $i -le 10000 ]; do echo "hello Linux $i"; let i++;done > big.txt
more
more big.txt
less
使用基本和more
一样,但是这个更方便,按键盘上的方向键就可以逐行查看,空格是一页一页的查
head 与 tail 就像它的名字一样的浅显易懂,它是用来显示开头或结尾某个数量的文字区块,head 用来显示档案的开头至标准输出中,而 tail 想当然尔就是看档案的结尾。
语法: head [参数]… [文件]…
功能:
head 用来显示档案的开头至标准输出中,默认head命令打印其相应文件的开头10行。
选项:
- -n<行数> 显示的行数
head big.txt
head -20 big.txt
tail 命令从指定点开始将文件写到标准输出.使用tail命令的-f选项可以方便的查阅正在改变的日志文件,tail -f filename会把filename里最尾部的内容显示在屏幕上,并且不但刷新,使你看到最新的文件内容.
语法: tail[必要参数][选择参数][文件]
功能: 用于显示指定文件末尾内容,不指定文件时,作为输入信息进行处理。常用查看日志文件。
选项:
-f 循环读取
-n<行数> 显示行数
tail big.txt
tail -20 big.txt
管道
head -8010 big.txt | tail -11
|
就是管道的意思,将上一条的输出指令交给第二条指令wc -l big.txt
head -8010 big.txt | tail -11 | wc -l
head -8010 big.txt | tail -11 | tac
我们可以通过管道对指令进行集连
date显示
date 指定格式显示时间: date +%Y:%m:%d
date 用法:date [OPTION]… [+FORMAT]
%H : 小时(00…23)
%M : 分钟(00…59)
%S : 秒(00…61)
%X : 相当于 %H:%M:%S
%d : 日 (01…31)
%m : 月份 (01…12)
%Y : 完整年份 (0000…9999)
%F : 相当于 %Y-%m-%d
date -s //设置当前时间,只有root权限才能设置,其他只能查看。
date -s 20080523 //设置成20080523,这样会把具体时间设置成空00:00:00
date -s 01:01:01 //设置具体时间,不会对日期做更改
date -s “01:01:01 2008-05-23″ //这样可以设置全部时间
date -s “01:01:01 20080523″ //这样可以设置全部时间
date -s “2008-05-23 01:01:01″ //这样可以设置全部时间
date -s “20080523 01:01:01″ //这样可以设置全部时间
时间->时间戳:date +%s
时间戳->时间:date -d@1508749502
Unix时间戳(英文为Unix epoch, Unix time, POSIX time 或 Unix timestamp)是从1970年1月1日(UTC/GMT的
午夜)开始所经过的秒数,不考虑闰秒。
date
Y
必须是大写,还有时分秒
date +%Y-%m-%d_%H:%M:%S
我们可以使用
date +%s
来查看时间戳
cal命令可以用来显示公历(阳历)日历。公历是现在国际通用的历法,又称格列历,通称阳历。“阳历”又名“太阳历”,系以地球绕行太阳一周为一年,为西方各国所通用,故又名“西历”。
命令格式: cal [参数][月份][年份]
功能: 用于查看日历等时间信息,如只有一个参数,则表示年份(1-9999),如有两个参数,则表示月份和年份
常用选项:
- -3 显示系统前一个月,当前月,下一个月的月历
- -j 显示在当年中的第几天(一年日期按天算,从1月1号算起,默认显示当前月在一年中的天数)
- -y 显示当前年份的日历
cal
cal -3
cal -j
cal -y
- Linux下find命令在目录结构中搜索文件,并执行指定的操作。
- Linux下find命令提供了相当多的查找条件,功能很强大。由于find具有强大的功能,所以它的选项也很多,其中大部分选项都值得我们花时间来了解一下。
- 即使系统中含有网络文件系统( NFS),find命令在该文件系统中同样有效,只你具有相应的权限。
- 在运行一个非常消耗资源的find命令时,很多人都倾向于把它放在后台执行,因为遍历一个大的文件系统可能会花费很长的时间(这里是指30G字节以上的文件系统
语法: find pathname -options
功能: 用于在文件树种查找文件,并作出相应的处理(可能访问磁盘)
常用选项:
- -name 按照文件名查找文件。
find 路径 -name 名称
*
find / -name *.c
.c
结尾的文件语法: grep [选项] 搜寻字符串 文件
功能: 在文件中搜索字符串,将找到的行打印出来
常用选项:
- -i :忽略大小写的不同,所以大小写视为相同
- -n :顺便输出行号
- -v :反向选择,亦即显示出没有 ‘搜寻字符串’ 内容的那一行
grap "999" big.txt
我们来看第一个选项
-i
的话只会匹配关键字grep "bit" tmp.txt
我们来看第二个选项
grep -i -n "bit" tmp.txt
我们来看第三个选项
-v :反向选择,亦即显示出没有 ‘搜寻字符串’ 内容的那一行
刚刚有的就不打印,反向匹配
-
后面是可以连续写的grep -inv "bit" tmp.txt
grep -inv "bit" tmp.txt | tac
cat
和统计行数wc -l
命令cat tmp.txt | grep -inv "bit" tmp.txt | tac | wc -l
接下来我们谈谈打包和压缩
语法: zip 压缩文件.zip 目录或文件
功能: 将目录或文件压缩成zip格式
常用选项:
- -r 递 归处理,将指定目录下的所有文件和子目录一并处理
which zip
which unzip
yum install -y zip unzip
complete
就说明安装成功了touch file1 file2 file3 file4 file5
zip -r 111.zip 111
unzip 111.zip
本文重点讲了重定向 | 文件概念 | 查看文件 | 查看时间 | 查找文件 | 基本的解压缩
如果有帮助,希望看完后可以三连一下~~谢谢大家!!!