shell读取依次读取TXT每行内容
时间: 2023-10-17 18:16:26 浏览: 189
可以使用 `read` 命令读取 TXT 文件中的每一行内容。具体操作如下:
```bash
#!/bin/bash
# 打开 TXT 文件
exec < input.txt
# 读取每一行内容
while read line
do
echo $line
done
```
其中,`input.txt` 是你要读取的 TXT 文件名,`$line` 变量用于存储每一行的内容。该脚本会依次读取 TXT 文件中的每一行内容,并将其输出到终端中。如果你需要对每一行内容进行处理,可以在 `while` 循环中添加相应的操作。
相关问题
shell脚本如何依次读取文本每行最后一个:后面的文本,并把读取的内容赋值变量
可以使用shell脚本中的while循环和sed命令来实现这个功能。具体步骤如下:
1. 打开文本文件
```bash
file="filename.txt"
```
2. 逐行读取文本内容
```bash
while read line
do
# 对每一行进行处理
done < "$file"
```
3. 在每行中找到最后一个冒号“:”的位置,并截取冒号后面的文本
```bash
index=$(echo "$line" | sed 's/.*:\(.*\)/\1/') # 找到最后一个冒号的位置,并截取冒号后面的文本
content=$(echo "$index" | sed 's/^[ \t]*//;s/[ \t]*$//') # 去掉文本两端的空格
```
4. 将截取到的内容赋值给变量
```bash
variable="$content"
```
完整代码如下:
```bash
file="filename.txt"
while read line
do
index=$(echo "$line" | sed 's/.*:\(.*\)/\1/')
content=$(echo "$index" | sed 's/^[ \t]*//;s/[ \t]*$//')
variable="$content"
# 对变量进行处理
echo "$variable"
done < "$file"
```
shell脚本如何依次读取文本每行最后一个/后面的文本,并把读取的内容赋值变量
可以使用awk命令来实现这个功能。具体步骤如下:
1. 打开文本文件
```bash
file="filename.txt"
```
2. 使用awk命令逐行读取文本内容,并截取冒号后面的文本
```bash
awk -F ":" '{print $NF}' "$file" | while read content
do
# 去掉文本两端的空格
variable=$(echo "$content" | awk '{$1=$1};1')
# 对变量进行处理
echo "$variable"
done
```
完整代码如下:
```bash
file="filename.txt"
awk -F ":" '{print $NF}' "$file" | while read content
do
variable=$(echo "$content" | awk '{$1=$1};1')
# 对变量进行处理
echo "$variable"
done
```
其中,awk命令的-F参数指定了分隔符为冒号“:”,$NF表示最后一个字段,即冒号后面的文本。使用while循环逐行读取每个冒号后面的文本,并使用echo和awk命令去掉文本两端的空格,最后将内容赋值给变量进行处理。
阅读全文