目录
前言
echo指令(简述)
Linux的设计理念
输出重定向操作符 >
追加输出重定向操作符 >>
输入重定向操作符 <
补充知识
学前补充
more指令
less指令
head指令
tail指令
查看文件中间的内容
利用输出重定向实现
利用管道“ | ”实现
wc指令
一种特殊机制:管道 |
这应该是Linux基本指令倒数第二篇了,加油再多学一点~
语法:echo [选项] 打印信息
功能:输出文本或变量的值。它通常被用于脚本编程、调试和打印信息
常见使用方式:
1、echo 打印信息,将要打印的信息显示在屏幕上:
2、echo 打印信息 > 文件名,将打印信息写入文件中,若该文件不存在则先创建后打印:
"一切皆文件" 是 Linux 的一个重要设计理念之一。在 Linux 中,几乎所有的设备、文件和资源都被视为文件。那么我们的显示器也就是屏幕作为一个输出设备,也可以被视为一个文件,利用echo打印在屏幕上的信息就可以理解为向屏幕文件中写入一个该信息,而我们利用重定向操作符>实现了将本该写在屏幕文件中的信息写在了log.txt文件中,这个过程就叫做“输出重定向”
语法:> 文件名
功能:向文件中写入信息,写入时覆盖原来内容
常见使用方式:
1、在上面的例子中,我们利用echo和>的配合,成功的将打印信息写入了文件中,同时由于没有对应的文件,所以系统创建了一个新的名叫log.txt的文件,那么如果我们想不为文件中写入信息就想直接创建一个新的文件,是不是可以直接>呢?答案是肯定的:
因此,我们除了利用touch 文件名的形式创建新文件,还可以用> 文件名也可以创建新文件
2、若我们想为包含“hello linux”信息的log.txt文件中继续追加信息时,我们会发现新追加的信息会覆盖掉原来的信息:
如果我们将一个空的信息传入log.txt文件呢?
我们发现文件貌似已经被置空了,但是文件实际的大小仍为1,这个1代表文件的换行符,所以即使是传入一个空的信息该文件依然不为空,所以我们该怎么办?
我们可以利用重复使用 > 文件名的方式来清空一个文件,此时文件的实际大小变为0
语法:>> 文件名
功能:向文件结尾处写入信息,只追加不覆盖
这两个操作符,在c语言中其实就是两种不同的文件操作方式
对>操作符,它对应的C语言代码是:
即以只写w的方式(覆盖写入)打开log.txt文件,然后利用fputs函数向文件中写入字符串"hello c"(图中一些内容懒得更改了懂得大致意思即可)
对于>>操作符,它对应的C语言代码是:
即以追加a的方式(只追加不覆盖)打开log.txt文件,然后利用fputs函数向文件中追加写入字符串"hello c"(图中的hello 111懒得改成c了)
关于C语言中的文件操作方法,可以查看我的这篇文章:文件操作函数---C语言版本
有了输出重定向操作符就会有输入重定向操作符
语法:< 文件名
功能:将原本默认从键盘文件中读取信息并打印在显示器上的道路,切换至从指定文件中读取信息并打印在显示器上
一些解释:
1、关于输入重定向的解释
直接使用cat指令就会默认从键盘文件中读取信息,即我们在键盘中输入一个值1,屏幕上就会将我们输入的内容打印出来:
而cat < 文件名 指令就会使原来默认从键盘文件中读取信息打印在显示器上,转变为从我们指定的文件中读取信息并打印在显示器上:
2、关于cat < 文件名 与cat 文件名的解释:
虽然cat < 文件名 与cat 文件名 所显示的内容是一样的
但是两者在功能和行为上有所不同(cat < 文件名指令会更加复杂且有用):
1.cat 文件名用于将指定文件的内容输出到终端(标准输出),不修改原始文件,只是将其内容显示出来。
2.cat < 文件名用于将指定文件作为输入,并将其内容传递给另一个命令或程序。这种方式称为输入重定向。通过
<
操作符,可以从指定的文件中读取数据并传递给后续处理。
假设你有一个可执行程序 "a.out" 接受从标准输入读取数据并进行处理。现在你想使用 "input.txt" 中的数据作为程序的输入,可以使用以下命令:
cat < input.txt | ./a.out
"input.txt" 文件中可以包含任意文本内容,它可以是纯文本、代码、配置文件等等。这个文件的内容取决于你想要在程序或命令中使用的数据,下面是一些示例:
1. 纯文本:
This is a sample text file. It can contain multiple lines of text.
2. 代码:
#include
int main() { printf("Hello, World!\n"); return 0; } 3. 配置文件(例如 JSON 或 XML):
{ "name": "John Doe", "age": 25, "city": "New York" }
4. 数据集合(例如 CSV 格式):
Name,Age,City John Doe,25,New York Jane Smith,30,San Francisco
在一个名为 "input.txt" 的文件中,你可以放置任何类型的文本内容,具体取决于你程序或命令需要处理的数据类型。如果需要对该数据进行进一步处理,还可以将其传递给其他命令或程序。
总结:
- cat 文件名:用于显示文件的内容到终端,不修改原始文件。
- cat > 文件名:用于将指定文件的内容作为输入,并传递给后续处理(命令或程序)。
对于<操作符,它对应的C语言代码是:
即以只读r的方式(读取字符)打开log.txt文件,然后利用fgets函数将文件中的字符逐个的打印在显示器上
在上面我们提到了Linux中一条重要的设计理念:一切皆文件。基于这条设计理念,Linux就可以以统一的方式来进行文件/设备(键盘,显示器,磁盘、终端等)的访问。
对于文件的访问我们可以理解,但是设备除了键盘外,显示器甚至是磁盘终端这些都可以被视为文件吗?
我们都知道,我们在使用Linux的时候的大黑框称为终端,而且我们可以创建多个终端,而每次的创建终端都会在伪终端文件夹中创建一个新以0 1 2 3 这些数字为名字的终端文件(默认有0和1终端):
如果你还不确定,那么请看下面这张图:
可以发现,我们可以利用echo 打印信息 > 目录/文件 的形式向另外两个终端中打印信息,所以终端也可以被视为一个文件,这也就是Linux一切皆文件理念的体现。
也因此,如果你学会了在Linux中操作文件,你也就相当于学会了对于硬件的操作,这也是为什么在嵌入式学习中我们选取的操作系统是Linux操作系统。
我们在学习more、less、head、tail指令之前先创建一个文本大文件,具体指令如下:
i=1; while [$i -le 10000]; do echo "hello linux $i"; let i++; done
这么做的原因是因为cat指令只方便用于查看小文本文件若是文本文件过大,比如指令中的十万行句子cat指令会将这十万行句子全部打印当我们想要向上翻找时就会显得很麻烦,所以就需要使用more、less、head、tail这个指令来方便我们查看大文本文件的信息,我们在学习前先创建一个文本大文件是为了方便后面的举例,我们再将这些信息存入output.txt文件中,文件大小从0变为1788895:
语法:more [选项][文件]
注意事项:
打满一个屏幕就停下,用户可以使用回车逐行向下查看剩余信息:
但是,如果我们想要查看第9999行的信息,也要按好久的回车且不能使用上下箭头来回上下翻看,所以我们并不推荐使用more指令来查看大文本文件,我们更推荐使用less指令来查看大文本文件
语法:less [选项][文件]
实际效果与选项内容不再展示,可以自行实践
语法:head [-参数] [文件]
语法:tail [-参数] [选项] [文件]
1、参数前记得加上-
那么如何查看文件的中间内容呢?
1、将文件前五万行信息输出至新建的临时文件new.txt
2、利用tail读取new.txt中倒数后十行的内容
缺点:需要创建临时文件
语法:wc [选项] 文件名
功能:统计文件或标准输入中的字节数、单词数和行数
常用选项:
-l
:只显示行数-w
:只显示单词数-c
:只显示字节数常见的使用方式:
1、wc -l 文件名,查看当前文件的行数
2、wc -w 文件名,查看当前文件的单词数
3、wc -c 文件名:查看当前文件的字节数
语法:命令1 | 命令2 | ...
功能:将一个命令的输出结果直接传递给另一个命令作为输入
常见使用方式:
1、与wc -l 文件名指令配合查找文件的中间部分内容
2、Linux中多条指令可以利用管道进行级联
3、查看文本文件末尾与less指令级联
4、级联(Cascading)是指将多个操作或组件连接在一起形成一个连续的序列,使得每个操作的输出作为下一个操作的输入。这种连接可以形成复杂而强大的功能和流程。
~over~