在python中,迴圈有一個語句:for語句。
簡單的for迴圈例子
>>> hello = "world">>> for i in hello:... print i... world
上面這個for迴圈是怎麼工作的呢?
hello這個變數引用的是"world"這個str類型的資料
變數 i 通過hello找到它所引用的"world",然後從第一字元開始,依次獲得該字元的引用。
當 i="w"的時候,執行print i,列印出了字母w,結束之後迴圈第二次,讓 i="e",然後執行print i,列印出字母e,如此迴圈下去,一直到最後一個字元被列印出來,迴圈自動結束
順便補充一個print的技巧,上面的列印結果是豎著排列,也就是每列印一個之後,就自動換行。如果要讓列印的在一行,可以用下面的方法,在列印的後面加一個逗號(英文)
>>> for i in hello:... print i,... w o r l d>>> for i in hello:... print i+",", #為了美觀,可以在每個字元後面加一個逗號分割... w, o, r, l, d,>>>
因為可以通過使用索引編號(位移量)做為下表,得到某個字元。所以,還可以通過下面的迴圈方式實現上面代碼中同樣功能:
>>> for i in range(len(hello)):... print hello[i]... world
其工作方式是:
len(hello)得到hello引用的字串的長度,為5
range(len(hello),就是range(5),也就是[0, 1, 2, 3, 4],對應這"world"每個字母的編號,即位移量。
for i in range(len(hello)),就相當於for i in [0,1,2,3,4],讓i依次等於list中的各個值。當i=0時,列印hello[0],也就是第一個字元。然後順序迴圈下去,直到最後一個i=4為止。
以上的迴圈舉例中,顯示了對字str的字元依次擷取,也涉及了list,感覺不過癮呀。那好,看下面對list的迴圈:
>>> ls_line['Hello', 'I am qiwsir', 'Welcome you', '']>>> for word in ls_line:... print word... HelloI am qiwsirWelcome you>>> for i in range(len(ls_line)):... print ls_line[i]... HelloI am qiwsirWelcome you
上一個台階
我們已經理解了for語句的基本工作流程,如果寫一個一般化的公式,可以這麼表示:
for 目標 in 對象:
動作陳述式
用for語句來解決一個實際問題。
例:找出100以內的能夠被3整除的正整數。
分析:這個問題有兩個限制條件,第一是100以內的正整數,根據前面所學,可以用range(1,100)來實現;第二個是要解決被3整除的問題,假設某個正整數n,這個數如果能夠被3整除,也就是n%3(%是取餘數)為0.那麼如何得到n呢,就是要用for迴圈。
以上做了簡單分析,要實現流程,還需要細化一下。按照前面曾經講授過的一種方法,要畫出問題解決的流程圖。
下面寫代碼就是按圖索驥了。
代碼:
#! /usr/bin/env python#coding:utf-8aliquot = []for n in range(1,100): if n%3 == 0: aliquot.append(n)print aliquot
代碼運行結果:
[3, 6, 9, 12, 15, 18, 21, 24, 27, 30, 33, 36, 39, 42, 45, 48, 51, 54, 57, 60, 63, 66, 69, 72, 75, 78, 81, 84, 87, 90, 93, 96, 99]
這裡僅僅列舉一個簡單的例子,看官可以在這個例子基礎上深入:列印某範圍內的偶數/奇數等。