曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 3565|回复: 0
打印 上一主题 下一主题

迭代文件中的行,行中的单词,单词中的字符

[复制链接]

4917

主题

5879

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34382
跳转到指定楼层
楼主
发表于 2012-4-6 13:39:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
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 个。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2024-5-15 16:50 , Processed in 0.076879 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表