1 man指令(重要)
Linux 的命令有很多参数,我们不可能全记住,我们可以通过查看联机手册获取帮助。访问 Linux 手册页的命令是 :
man 语法 : man [选项] 命令
常用选项
-k 根据关键字搜索联机帮助 ;
num 只在第num章节找 ;
-a 将所有章节的都显示出来,比如 man printf 它缺省从第一章开始搜索,知道就停止,用a选项,当按下q退出,他会继续往后面搜索,直到所有章节都搜索完毕。
解释一下,mam手册总共分为9章:
1 是普通的命令 |
2 是系统调用 , 如 open,write 之类的 ( 通过这个,至少可以很方便的查到调用这个函数,需要加什么头文件 )
3 是库函数 , 如 printf,fread4 是特殊文件 , 也就是 /dev 下的各种设备文件
4 特别的文件
5 是指文件的格式 , 比如 passwd, 就会说明这个文件中各个字段的含义
6 是给游戏留的 , 由各个游戏自己定义
7 是附件还有一些变量 , 比如向 environ 这种全局变量在这里就有说明
8 是系统管理用的命令 , 这些命令只能由 root 使用 , 如 ifconfifig
9 内核例程(非标准)
我们可以试试:
man man
我们可以怎样去查找c语言中printf呢?
man 3 printf
然后就能够跳转到man手册:
退出的话按:q
至于查找其他选项大家下来可以自己试试。
2 more指令
语法:more [选项][文件]
功能:more命令,功能类似 cat
常用选项:
- -n 显示前n行 (这里的n是敲数字,不是敲n)
- q 退出more
这个指令的功能类似与cat都是查看目标文件的内容,不过具体细节效果有所差异,在讲more之前我们再来学习一个指令:echo
正如你看到的那样,echo后面跟一堆字符就能把字符打印到屏幕上,那带不带" "有啥区别吗?
严格说区别不大,但是带上" "能够更方便我们知道后面是字符串。
那我们能用echo将字符串打印到文件里面吗?
答案是当然可以的
我们可以看到刚开始我们当前目录下是没有text.c这个文件的,可以当我们执行了:
echo "hello linux" > text.c
就会生成一个text.c文件并且把字符写入到文件中,而这个 > 我们叫做输出重定向。
这个概念大家一定要记住很重要,并且输出重定向是覆盖式的写入的,什么意思呢?
通过上面我们可以知道当我们执行一个新的输出重定向的时候会直接将原来文件内容清空,然后再写入,那有没有什么方法不清空原来数据呢?
答案是有的:当我们执行:
echo "hello linux" >> text.c
这个 >> 就叫做追加重定向,它会保留原来的数据。
有了输出重定向那有没有输入重定向呢?
答案是有的
通过上面我们可以知道上述两种方法都能将文件中内容读取出来,但是方法却是不同的,第一种用的是输入重定向方法,第二种是用的cat指令这种方法,这两种方法的具体差异我们后面的学习会详细讲解,这里就不在多说了。而这个 < 就叫做输入重定向。
现在回归正题,more究竟是怎么使用的呢?
我们创建一个文本内容很长的文件,这里我们使用Shell脚本的命令,我也看不懂,大家目前了解一下就好,后面我们会系统的学系这个的。
cnt=0; while [ $cnt -le 1000 ]; do echo "hello $cnt"; let cnt++; done > mylog.txt
假如我们还是用cat去打开的话:
他会直接跳转到最后几行,前面的内容就被很快的跳过,想要找到就得一行一行的找,很麻烦
那我们就可以使用more:
使用命令:
more mylog.txt
光标会定位到当前屏幕所能容纳的最多内容这里,并且不会继续往下走,再敲回车才会往下走:
每敲一次回车往下走一行,直到走到最后。但是它的缺陷是并不能往回走,就是当你错过了就无法再回去了,更好的处理方法就是我们要讲的下一个命令:less
3 less指令(重要)
less 工具也是对文件或其它输出进行分页显示的工具,应该说是linux正统查看文件内容的工具,功能极其强大。
less 的用法比起 more 更加的有弹性。在 more 的时候,我们并没有办法向前面翻, 只能往后面看但若使用了 less 时,就可以使用 [pageup][pagedown] 等按键的功能来往前往后翻看文件,更容易用来查看一个文件的内容!
除此之外,在 less 里头可以拥有更多的搜索功能,不止可以向下搜,也可以向上搜
语法: less [参数] 文件
功能 :
less与more类似,但使用less可以随意浏览文件,而more仅能向前移动,却不能向后移动,而且less在查看之前 不会加载整个文件。
选项 :
-i 忽略搜索时的大小写
-N 显示每行的行号
/字符串:向下搜索“字符串”的功能
?字符串:向上搜索“字符串”的功能
n:重复前一个搜索(与 / 或 ? 有关)
N:反向重复前一个搜索(与 / 或 ? 有关)
q:quit
具体用法:
less -N mylog.txt
我们可以通过上下翻阅来查找我们想要查询的内容,还可以通过/字符串 和?字符串 来更方便的查找,其他功能你们也可以下去试试,这里就不在多说了,less的功能总的来说比more强大了不少。
4 head指令和tail指令
这两个指令都比较简单,顾名思义,它是用来显示开头或结尾某个数量的文字区块,head 用来显示档案的 开头至标准输出中,而 tail 想当然就是看档案的结尾。
语法: head [参数]... [文件]...
功能 :
head 用来显示档案的开头至标准输出中,默认head命令打印其相应文件的开头10行 。
选项 :
-n<行数> 显示的行数
tail 命令从指定点开始将文件写到标准输出 . 使用 tail 命令的 -f 选项可以方便的查阅正在改变的日志文件 ,tail -f fifilename 会把 fifilename 里最尾部的内容显示在屏幕上 , 并且不但刷新 , 使你看到最新的文件内容 .
语法: tail[必要参数][选择参数][文件]
功能: 用于显示指定文件末尾内容,不指定文件时,作为输入信息进行处理。常用查看日志文件。
选项:
-f 循环读取
-n<行数> 显示行数
这个很简单,大家都很容易理解,那么现在问题来了,如何显示文件中第295行到300行的内容呢?
有人会说,这还不简单吗?将该文件的前300行输出重定向到一个临时文件tmp.txt中,再用tail指令取最后5行内容不就行了吗
这种方法是可取的,我们可以来试试:
这样我们就创建好了临时文件,我们可以通过临时文件来得到我们想要的数据
那如果我们再加一个限制条件,不准使用临时文件来保存呢?
这个时候就可以用管道(|)来处理了
命令:
cat mylog.txt | head -300 | tail -5
我们发现用管道来处理的确方便了不少,而管道也正如它的名字一样,就是作为一种中介条件将不同命令组合起来用,我们甚至还可以这样用:
最后的这个wc又是什么鬼呢?
wc通俗来讲其实是用来统计行数的,我们可以来看看:
使用这个命令可以统计出文件有多少行,而在上面我们最后用了管道来统计出295行到300行之间的行数,不难看出使用多个管道命令最终执行会落实到最后一个命令上去。