shell 循环读取文件中每一行的方法详解

当需要在shell脚本中读取文件中的每一行进行处理时,可以使用while循环或for循环。下面将详细介绍这两种方法。

 

方法一:使用while循环


使用while循环是一种常见的读取文件中每行的方法。该方法的基本语法如下:

while read line
do
    # 处理每一行的代码
done < filename

其中,read line命令用于读取文件中的每一行,并将其存储在line变量中。< filename表示从文件中读取输入。

以下是一个示例,演示如何使用while循环读取文件中的每一行:

#!/bin/bash

filename="example.txt"

while read line
do
    echo $line
done < $filename

在上面的示例中,我们使用while循环读取example.txt文件中的每一行,并使用echo命令将其输出到终端。

 

 

方法二:使用for循环


使用for循环也是一种读取文件中每一行的方法。该方法的基本语法如下:

for line in $(cat filename)
do
    # 处理每一行的代码
done

其中,$(cat filename)命令用于将文件的内容读取到一个字符串中,并使用空格或换行符分隔每一行。for循环将字符串中的每一行赋值给line变量。

以下是一个示例,演示如何使用for循环读取文件中的每一行:

#!/bin/bash

filename="example.txt"

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

在上面的示例中,我们使用for循环读取example.txt文件中的每一行,并使用echo命令将其输出到终端。

 

 

示例说明


以下是两个示例,演示如何使用shell脚本循环读取文件中每一行的方法。

示例1:使用while循环读取文件中每一行

假设有一个名为example.txt的文件,其中包含以下内容:

apple
banana
orange

我们可以使用以下shell脚本使用while循环读取文件中的每一行:

#!/bin/bash

filename="example.txt"

while read line
do
    echo $line
done < $filename

运行上面的脚本,将输出以下内容:

apple
banana
orange

示例2:使用for循环读取文件中每一行

假设我们有一个名为example.txt的文件,其中包含以下内容:

apple
banana
orange

我们可以使用以下shell脚本使用for循环读取文件中的每一行:

#!/bin/bash

filename="example.txt"

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

运行上面的脚本,将输出以下内容:

apple
banana
orange

 

总结


使用while循环和for循环都是读取文件中每一行的常见方法。while循环适用于处理大型文件,而for循环适用于处理小型文件。在使用这两种方法时,需要注意文件中每一行的格式,以便正确读取和处理每一行的内容。

你可能感兴趣的:(Shell,shell)