【Shell 命令集合 文档编辑】Linux 格式化文本文件fmt命令使用教程

简介: 【Shell 命令集合 文档编辑】Linux 格式化文本文件fmt命令使用教程

Shell 命令专栏:Linux Shell 命令全解析

描述

在Linux中,fmt命令用于格式化文本文件的内容。它会将输入的文本重新格式化为指定的行宽,以适应终端或打印机的输出。以下是fmt命令的详细描述:

语法

fmt [OPTION]... [FILE]...

选项

  • -c, --crown-margin:将每一段的第一行与页边对齐。
  • -p, --prefix:在每一行的前面添加一个空格。
  • -s, --split-only:只拆分长行,不进行换行。
  • -t, --tagged-paragraph:处理标记段落而不是正常段落。
  • -u, --uniform-spacing:保持输入文本中的空格不变。
  • -w, --width=WIDTH:设置输出的行宽,默认为75个字符。
  • --help:显示帮助信息并退出。
  • --version:显示版本信息并退出。

示例

$ cat file.txt
This is a sample text file used for demonstration purposes.
$ fmt file.txt
This is a sample text file used for demonstration purposes.
$ fmt -w 20 file.txt
This is a sample
text file used for
demonstration
purposes.
$ fmt -c file.txt
This is a sample text file used
for demonstration purposes.
$ fmt -s file.txt
This is a sample text file used for demonstration purposes.
$ fmt -p file.txt
 This is a sample text file used for demonstration purposes.

以上是fmt命令的基本用法和部分选项示例。它可以根据需要对文本进行格式化,使其更易于阅读和输出。


语法格式

fmt [选项] [文件...]

参数说明

  • -w <宽度>: 指定每行的最大宽度。默认宽度为75个字符。
  • -c: 将每个段落视为单独的行,并根据句子进行换行。
  • -t: 保留输入文本中的标签行,并将其与相邻的非标签行合并为一行。
  • -s: 不执行任何操作,只是将输入文本输出到标准输出。
  • -p: 在每行前添加一个空格,用于缩进段落。
  • -d: 删除所有空行。
  • -u: 不执行任何操作,只是将输入文本输出到标准输出,但不进行断行处理。
  • -h: 显示帮助信息。

错误情况

  • 如果指定的文件不存在或无法读取,则会显示错误消息。
  • 如果使用无效的选项或参数,则会显示错误消息。
  • 如果发生其他未知错误,则会显示相应的错误消息。

通过以上参数说明和错误情况,可以更好地理解和使用fmt命令。

注意事项

在使用Linux Shell的fmt命令时,有几个注意事项需要注意:

  1. fmt命令默认将输入文本进行断行处理,并将每行最大宽度设置为75个字符。可以使用-w选项来指定不同的宽度。在选择宽度时,需要根据实际情况和显示效果进行调整。
  2. fmt命令会将每个段落视为单独的行,并根据句子进行换行。可以使用-c选项来启用此功能。在使用该选项时,需要确保输入文本的段落和句子结构正确,以获得期望的换行效果。
  3. 使用-t选项可以保留输入文本中的标签行,并将其与相邻的非标签行合并为一行。这在处理包含标签的文本文件时很有用。但需要注意,如果标签行太长,可能会导致行宽超过指定的宽度。
  4. 如果只想将输入文本输出到标准输出,而不进行断行处理,可以使用-u选项。这在需要保留原始文本格式的情况下很有用。
  5. 使用-p选项可以在每行前添加一个空格,用于缩进段落。这在需要对文本进行缩进的情况下很有用。但需要注意,如果段落中已经存在缩进,可能会导致缩进过多。
  6. 使用-d选项可以删除所有空行。这在需要去除文本中的空行时很有用。
  7. 在使用fmt命令时,需要注意输入文本的格式和内容。如果输入文本的段落和句子结构不正确,可能会导致断行效果不理想。因此,在使用fmt命令之前,最好先对输入文本进行预处理,确保其结构正确。
  8. 如果遇到任何错误或问题,fmt命令会显示相应的错误消息。可以通过查看错误消息来排查和解决问题。

通过遵守上述注意事项,可以更好地使用fmt命令,并获得期望的文本断行效果。


底层实现

fmt命令的底层实现是通过调用libfmt库来实现的。该库提供了一些函数和算法来对输入文本进行格式化处理。

在底层实现中,fmt命令首先会读取输入文本,并将其分成不同的段落。然后,对每个段落进行处理,包括断行、合并标签行、缩进等操作。

断行操作是fmt命令的核心功能之一。它通过使用贪婪算法来确定每行的最佳断点,以使每行的宽度不超过指定的宽度。贪婪算法会考虑词与词之间的空格、标点符号和换行符等因素,以获得最佳断行效果。

合并标签行操作是通过检查每行的内容来确定哪些行是标签行,并将其与相邻的非标签行合并为一行。这在处理包含标签的文本文件时很有用。

缩进操作是通过在每行前添加空格来实现的。可以通过-p选项来控制缩进的级别。

除了上述操作外,fmt命令还提供了一些其他功能,如删除空行、保留原始文本格式等。

总的来说,fmt命令的底层实现是基于libfmt库,通过一系列函数和算法来对输入文本进行格式化处理,以实现断行、合并标签行、缩进等功能。


示例

示例一

$ cat file1.txt
This is a sample text file used for demonstration purposes.
$ fmt file1.txt
This is a sample text file used for demonstration purposes.

示例二

$ cat file2.txt
This is a long line of text that needs to be formatted into multiple lines.
$ fmt -w 20 file2.txt
This is a long line
of text that needs to
be formatted into
multiple lines.

示例三

$ cat file3.txt
This is a paragraph. It consists of multiple sentences. Each sentence needs to be on a separate line.
$ fmt -c file3.txt
This is a paragraph. It consists of multiple sentences. Each sentence needs to be on a separate line.

示例四

$ cat file4.txt
This is a tagged paragraph.
> It starts with a tag symbol.
> Each line starts with a tag symbol.
$ fmt -t file4.txt
This is a tagged paragraph. It starts with a tag symbol. Each line starts with a tag symbol.

示例五

$ cat file5.txt
This is a sample text file used for demonstration purposes.
$ fmt -s file5.txt
This is a sample text file used for demonstration purposes.

示例六

$ cat file6.txt
This is a sample text file used for demonstration purposes.
$ fmt -p file6.txt
 This is a sample text file used for demonstration purposes.

示例七

$ cat file7.txt
This is a sample text file used for demonstration purposes.
$ fmt -w 30 -c file7.txt
This is a sample text file
used for demonstration
purposes.

以上是七个不同的fmt命令使用示例,每个示例都带有序号,并展示了不同的选项和效果。通过这些示例,可以更好地理解和使用fmt命令。


用c语言实现


以下是一个使用C语言代码实现fmt命令的示例:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_LINE_WIDTH 80
// 函数原型
void fmt(FILE *inputFile, FILE *outputFile, int lineWidth);
int main(int argc, char *argv[]) {
    // 检查命令行参数
    if (argc != 2) {
        printf("Usage: ./fmt <input_file>\n");
        return 1;
    }
    // 打开输入文件
    FILE *inputFile = fopen(argv[1], "r");
    if (inputFile == NULL) {
        printf("Error opening input file.\n");
        return 1;
    }
    // 打开输出文件
    FILE *outputFile = fopen("output.txt", "w");
    if (outputFile == NULL) {
        printf("Error opening output file.\n");
        return 1;
    }
    // 调用 fmt 函数进行格式化处理
    fmt(inputFile, outputFile, MAX_LINE_WIDTH);
    // 关闭文件
    fclose(inputFile);
    fclose(outputFile);
    printf("Formatting complete.\n");
    return 0;
}
// 格式化函数
void fmt(FILE *inputFile, FILE *outputFile, int lineWidth) {
    char line[MAX_LINE_WIDTH];
    int currentWidth = 0;
    while (fgets(line, sizeof(line), inputFile)) {
        // 去除行尾的换行符
        line[strcspn(line, "\n")] = '\0';
        // 如果行为空,直接写入输出文件
        if (line[0] == '\0') {
            fputs(line, outputFile);
            fputs("\n", outputFile);
            currentWidth = 0;
            continue;
        }
        // 如果当前行已经超过指定宽度,写入输出文件并重置当前宽度
        if (currentWidth + strlen(line) > lineWidth) {
            fputs("\n", outputFile);
            currentWidth = 0;
        }
        // 在当前行后添加空格或者换行符
        if (currentWidth > 0) {
            fputs(" ", outputFile);
            currentWidth++;
        }
        // 写入当前行内容
        fputs(line, outputFile);
        currentWidth += strlen(line);
    }
}

这个示例程序实现了一个简单的fmt命令,它将输入文件中的文本进行格式化处理,并将结果写入输出文件。程序通过逐行读取输入文件的内容,根据指定的行宽进行断行操作,并在每行后添加空格或换行符来实现格式化效果。

main函数中,首先检查命令行参数的数量,然后打开输入文件和输出文件。接下来,调用fmt函数来进行格式化处理,并传递输入文件、输出文件和行宽作为参数。最后,关闭文件并打印完成消息。

fmt函数中,使用fgets函数逐行读取输入文件的内容,并使用strcspn函数去除行尾的换行符。然后,根据行的内容进行处理。如果行为空,则直接写入输出文件,并重置当前宽度。如果当前行已经超过指定宽度,则在输出文件中写入换行符,并重置当前宽度。然后,在当前行后添加空格或换行符,并将当前行内容写入输出文件,同时更新当前宽度。

这个示例程序只是一个简单的实现,可能无法处理一些特殊情况,如标签行的合并等。要实现更完整的fmt命令,可能需要更复杂的算法和处理逻辑。


结语

在我们的探索过程中,我们已经深入了解了Shell命令的强大功能和广泛应用。然而,学习这些技术只是开始。真正的力量来自于你如何将它们融入到你的日常工作中,以提高效率和生产力。

心理学告诉我们,学习是一个持续且积极参与的过程。所以,我鼓励你不仅要阅读和理解这些命令,还要动手实践它们。尝试创建自己的命令,逐步掌握Shell编程,使其成为你日常工作的一部分。

同时,请记住分享是学习过程中非常重要的一环。如果你发现本博客对你有帮助,请不吝点赞并留下评论。分享你自己在使用Shell命令时遇到的问题或者有趣的经验,可以帮助更多人从中学习。

此外,我也欢迎你收藏本博客,并随时回来查阅。因为复习和反复实践也是巩固知识、提高技能的关键。

最后,请记住:每个人都可以通过持续学习和实践成为Shell编程专家。我期待看到你在这个旅途中取得更大进步!

目录
相关文章
|
3月前
|
存储 安全 Unix
七、Linux Shell 与脚本基础
别再一遍遍地敲重复的命令了,把它们写进Shell脚本,就能一键搞定。脚本本质上就是个存着一堆命令的文本文件,但要让它“活”起来,有几个关键点:文件开头最好用#!/usr/bin/env bash来指定解释器,并用chmod +x给它执行权限。执行时也有讲究:./script.sh是在一个新“房间”(子Shell)里跑,不影响你;而source script.sh是在当前“房间”里跑,适合用来加载环境变量和配置文件。
|
3月前
|
算法 Linux Shell
Linux实用技能:打包压缩、热键、Shell与权限管理
本文详解Linux打包压缩技巧、常用命令与原理,涵盖.zip与.tgz格式操作、跨系统传文件方法、Shell运行机制及权限管理,助你高效使用Linux系统。
Linux实用技能:打包压缩、热键、Shell与权限管理
|
3月前
|
存储 Shell Linux
八、Linux Shell 脚本:变量与字符串
Shell脚本里的变量就像一个个贴着标签的“箱子”。装东西(赋值)时,=两边千万不能有空格。用单引号''装进去的东西会原封不动,用双引号""则会让里面的$变量先“变身”再装箱。默认箱子只能在当前“房间”(Shell进程)用,想让隔壁房间(子进程)也能看到,就得给箱子盖个export的“出口”戳。此外,Shell还自带了$?(上条命令的成绩单)和$1(别人递进来的第一个包裹)等许多特殊箱子,非常有用。
|
5月前
|
Web App开发 缓存 安全
Linux一键清理系统垃圾:释放30GB空间的Shell脚本实战​
这篇博客介绍了一个实用的Linux系统盘清理脚本,主要功能包括: 安全权限检查和旧内核清理,保留当前使用内核 7天以上日志文件清理和系统日志压缩 浏览器缓存(Chrome/Firefox)、APT缓存、临时文件清理 智能清理Snap旧版本和Docker无用数据 提供磁盘空间使用前后对比和大文件查找功能 脚本采用交互式设计确保安全性,适合定期维护开发环境、服务器和个人电脑。文章详细解析了脚本的关键功能代码,并给出了使用建议。完整脚本已开源,用户可根据需求自定义调整清理策略。
619 1
|
7月前
|
Linux Shell
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
218 4
|
7月前
|
Linux Shell 数据安全/隐私保护
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
438 3
|
8月前
|
Linux Shell
在Linux、CentOS7中设置shell脚本开机自启动服务
以上就是在CentOS 7中设置shell脚本开机自启动服务的全部步骤。希望这个指南能帮助你更好地管理你的Linux系统。
667 25
|
8月前
|
Linux Shell
shell_42:Linux参数移动
总的来说,参数移动是Linux shell脚本中的一个重要概念,掌握它可以帮助我们更好地处理和管理脚本中的参数。希望这个解释能帮助你理解和使用参数移动。
188 18
|
10月前
|
Shell Linux
【linux】Shell脚本中basename和dirname的详细用法教程
本文详细介绍了Linux Shell脚本中 `basename`和 `dirname`命令的用法,包括去除路径信息、去除后缀、批量处理文件名和路径等。同时,通过文件备份和日志文件分离的实践应用,展示了这两个命令在实际脚本中的应用场景。希望本文能帮助您更好地理解和应用 `basename`和 `dirname`命令,提高Shell脚本编写的效率和灵活性。
766 32
|
存储 Shell Linux
Linux 如何更改默认 Shell
Linux 如何更改默认 Shell
Linux 如何更改默认 Shell