曲径通幽论坛

标题: 迭代文件中的行,行中的单词,单词中的字符 [打印本页]

作者: beyes    时间: 2012-4-6 13:39
标题: 迭代文件中的行,行中的单词,单词中的字符
1. 迭代文件中的行
可以使用 while 从标准输入依次读入文件中的每一行,下面是供测试文本,共 2 行:
# cat mulword.txt
welcome to www groad net
Groad is a forum

脚本代码:
[Bash shell] 纯文本查看 复制代码
#!/bin/bash

while read line
do

    echo $line

done < mulword.txt


运行输出:
# ./iterline.sh
welcome to www groad net
Groad is a forum

2. 迭代每行中的单词
测试文本和例一中的一样,下面是脚本代码:
[Bash shell] 纯文本查看 复制代码
#!/bin/bash

while read line
do

    for word in $line;
    do
        echo $word;
    done

done < mulword.txt

运行输出:
# ./tmp.sh
welcome
to
www
groad
net
Groad
is
a
forum

3. 迭代单词中的每个字符
可以使用一个 for 循环依次获取单词中的每个字符,但这里需要用到一点小技巧,如下所示:
[Bash shell] 纯文本查看 复制代码
#!/bin/bash

word=$1

for ((i = 0; i < ${#word}; i++))
do
    echo ${word:i:1};
done

运行输出:
# ./tmp2.sh word
w
o
r
d
上面,${#word} 可以计算出整个字串的长度。而  ${word:i:1} 这种形式是 ${string:start_position:No_of_characters} 。其中第 1 个冒号后的 start_position 表示字串中的起始位置,第 2 个冒号后的 No_of_characters 表示一次获取的字符数,这里是 1 个。




欢迎光临 曲径通幽论坛 (http://www.groad.net/bbs/) Powered by Discuz! X3.2