麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > Linux Shell > 正文

Shell腳本對文件中的行、單詞、字符進行迭代輸出示例

2020-07-27 19:12:21
字體:
來源:轉載
供稿:網友

在進行文本文件進行處理時,對文件件中的行、單詞、字符進行迭代和遍歷是非常常用的操作。而將一個簡單的循環用于迭代,再加上來自stdin或文件的重定向,這就是對文件中的行、單詞、和字符進行迭代的基本方法。

廢話不多說,馬上來看看怎么樣實現吧。

1、迭代文中的每一行

使用while循環從標準輸入中讀取,因為要在標準輸入中讀取,就要對文件進行重定向,使它重定向到stdin中,代碼如下:

復制代碼 代碼如下:

while read line; 
do 
echo $line; 
done < file.txt 

代碼的第一行從stdin中讀取一行,而stdin的來源為file.txt,因為最后一行用數據流重定向,把file.txt的內容重定向到了stdin。

2、迭代一行中的每一個單詞

我們可以用for循環來迭代一行中的單詞,代碼如下:

復制代碼 代碼如下:

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

代碼的第一行,從stdin中讀取一行,然后用for循環迭代一行中的所有單詞,并輸出,真是非常簡單實用。

3、迭代一個單詞中的每一個字符

從單詞中迭代每一個字符,可以說是這三種迭代中最困難的一種,因為從單詞中提取字符需要一定的技巧,其方法如下:

利用for循環對變量i進行迭代,迭代范圍從0到字符的長度-1。那如何取出單詞中的字符呢?我們可以借助一個特殊的表達式來取出單詞中的第i個字母,${string:start_position:count_of_characters},它的意思是,返回字符串string中,從第start_position起的count_of_characters個字符組成的字串,對于迭代一個單詞中的第一個字符,當然是從string的第i個字符起,返回長度為1的子串,這就是子串提取技術。所以代碼如下:

復制代碼 代碼如下:

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

注:${#word}返回變量word的值的長度,即單詞的長度。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 粉嫩av一区二区三区四区在线观看 | 国产精品久久久久久久久久东京 | 99999久久久久久 | 精品在线观看一区二区 | 久久久成人一区二区免费影院 | 欧美精品| 黄色免费在线电影 | 毛片福利| 免费欧美一级视频 | 欧美aaa | 毛片免费视频播放 | 欧美999| 午夜在线观看视频网站 | 欧洲精品久久久久69精品 | 成年人网站视频免费 | 久久伊人精品热在75 | 久夜草 | 久久久久久久久久综合 | 91精品国产综合久久久欧美 | 日韩精品中文字幕一区二区 | 久久精品中文字幕一区 | 麻豆视频在线观看 | 在线播放av片| 国产污污视频 | 欧美福利视频一区二区三区 | 福利在线免费 | 伊久在线| 久久免费看片 | 久久久aa| 日韩激情一区 | 成人在线网站 | 欧美无极品 | 天海翼无删减av三级在线观看 | 九九热精品在线 | 亚洲成人午夜精品 | 久久久午夜电影 | 国产精品久久久久久久不卡 | 欧美激情猛片xxxⅹ大3 | 欧美午夜网 | 欧美淫交 | 91精品国产综合久久婷婷香蕉 |