如何在 Bash 中循环遍历文件内容 ?

Bash (Bourne-Again SHell),是一种流行的命令行 SHell 脚本语言,因其简单和易用而被广泛使用。最常见的任务之一,可能需要使用 Bash 遍历文件的内容。

在本文中,我们将探索在 Bash 脚本中使用不同的方法来循环遍历文件内容,包括逐行和逐字读取。

使用 while 循环和 read 命令

while 循环结合 read 命令是在 Bash 中遍历文件内容的最常用方法。该方法逐行读取文件,对于处理无法装入内存的大文件特别有用。

复制代码
#!/bin/bash

filename="example.txt"

while IFS= read -r line
do
    echo "$line"
done < "$filename"

在本例中,我们使用 IFS 变量来指定字段的分隔符(默认情况下是换行符)。read 命令读取每一行,echo 命令将该行打印到控制台。

使用 for 循环和 cat 命令

循环遍历文件内容的另一种方法是使用 for 循环和 cat 命令。

这个方法比 while 循环和 read 命令效率低,因为它在循环之前将整个文件读入内存。

复制代码
#!/bin/bash

filename="example.txt"

for line in $(cat "$filename")
do
    echo "$line"
done

在这个例子中,我们使用 cat 命令来读取文件的全部内容,使用 for 循环遍历每一行。但是,该方法默认情况下使用空格(空格、制表符和换行符)拆分了内容,这可能导致处理每行有多个单词的文件时出现意外行为。

使用 IFS 进行单词循环

如果需要一个字一个字地处理文件,可以使用 IFS 变量将分隔符更改为空格。

复制代码
#!/bin/bash

filename="example.txt"

IFS=$' \t\n'
for word in $(cat "$filename")
do
    echo "$word"
done

在本例中,我们将 IFS 变量设置为空格,制表符,和换行字符,以单词为分隔循环遍历文件内容。

使用 awk 高级循环

对于更高级的文件处理,可以使用 awk 命令,这是一个功能强大的文本处理工具,具有内置循环功能。

复制代码
#!/bin/bash

filename="example.txt"

awk '{ for (i=1; i<=NF; i++) print $i }' "$filename"

在本例中,awk 读取文件并使用其内置变量 NF (字段数)和 $i(当前字段值)循环遍历每个字段(单词),此方法对于更复杂的文本操作任务特别有用。

我的开源项目

相关推荐
归叶再无青5 天前
web服务安装部署、性能升级等(Apache、Nginx)
运维·前端·nginx·云原生·apache·bash
归叶再无青5 天前
企业级web服务(Tomcat开源web应用服务器)
运维·前端·开源·tomcat·bash
chao_7896 天前
构建start_app.sh,实现快速启动项目
python·bash·终端·前后端
笨笨D幸福6 天前
应用程序重定向技术(Shim)
bash·scoop·shim
xuchaoxin13757 天前
bash@bash帮助命令help@bash命令可用选项设置@bash -c@set命令@set --
bash
ol木子李lo8 天前
Linux 命令备忘录
linux·运维·服务器·windows·编辑器·ssh·bash
dingdingfish9 天前
Bash学习 - 第10章:Installing Bash
bash·make·shell·install·configure·5.3
dingdingfish9 天前
Bash学习 - 第8章:Command Line Editing,第3节:Readline Init File
bash·init·bind·readline
dingdingfish10 天前
Bash学习 - 第8章:Command Line Editing,第6-8节:Programmable Completion
bash·shell·completion·complete·compgen·compopt
dingdingfish11 天前
Bash学习 - 第8章:Command Line Editing,第4-5节:Bindable Readline Commands
bash·emacs·vi·bind·readline