Python for 循環語句
Python for 循環可以遍曆任何序列的項目,如一個(ge) 列表或者一個(ge) 字符串。
語法:
for 循環的語法格式如下:
for iterating_var in sequence: statements(s)
流程圖:
實例:
#!/usr/bin/python # -*- coding: UTF-8 -*- for letter in 'Python': # 第一個(ge) 實例 print '當前字母 :', letter fruits = ['banana', 'apple', 'mango'] for fruit in fruits: # 第二個(ge) 實例 print '當前字母 :', fruit print "Good bye!"
以上實例輸出結果:
Current Letter : P
Current Letter : y
Current Letter : t
Current Letter : h
Current Letter : o
Current Letter : n
Current fruit : banana
Current fruit : apple
Current fruit : mango
Good bye!
通過序列索引迭代
另外一種執行循環的遍曆方式是通過索引,如下實例:
#!/usr/bin/python # -*- coding: UTF-8 -*- fruits = ['banana', 'apple', 'mango'] for index in range(len(fruits)): print '當前水果 :', fruits[index] print "Good bye!"
以上實例輸出結果:
當前水果 : banana
當前水果 : apple
當前水果 : mango
Good bye!
以上實例我們(men) 使用了內(nei) 置函數 len() 和
range()函數 ,
len() 返回列表的長度,即元素的個(ge) 數。
range() 返回一個(ge) 序列的數。
循環使用 else 語句
在 Python 中,for … else 表示這樣的意思,
for 中的語句和普通的沒有區別,
else 中的語句會(hui) 在循環正常執行完(即
for 不是通過
break 跳出而中斷的)的情況下執行,
while … else 也是一樣。
如下實例:
#!/usr/bin/python # -*- coding: UTF-8 -*- for num in range(10,20): # 迭代 10 到 20 之間的數字 for i in range(2,num): # 根據因子迭代 if num%i == 0: # 確定第一個(ge) 因子 j=num/i # 計算第二個(ge) 因子 print '%d 等於(yu) %d * %d' % (num,i,j) break # 跳出當前循環 else: # 循環的 else 部分 print num, '是一個(ge) 質數'
以上實例輸出結果:
10 等於(yu) 2 * 5
11 是一個(ge) 質數
12 等於(yu) 2 * 6
13 是一個(ge) 質數
14 等於(yu) 2 * 7
15 等於(yu) 3 * 5
16 等於(yu) 2 * 8
17 是一個(ge) 質數
18 等於(yu) 2 * 9
19 是一個(ge) 質數
更多實例
打印 1-9 三角形陣列:
#!/usr/bin/python # -*- coding: UTF-8 -*- for i in range(1,11): for k in range(1,i): print k, print "\n"
以上實例輸出結果:
1
1 2
1 2 3
1 2 3 4
1 2 3 4 5
1 2 3 4 5 6
1 2 3 4 5 6 7
1 2 3 4 5 6 7 8
1 2 3 4 5 6 7 8 9
打印空心等邊三角形:
#!/usr/bin/python # -*- coding: UTF-8 -*- # 打印空心等邊三角形 rows = int(raw_input('輸入行數:\n')) for i in range(0, rows): for k in range(0, 2 * rows - 1): if (i != rows - 1) and (k == rows - i - 1 or k == rows + i - 1): print " * ", elif i == rows - 1: if k % 2 == 0: print " * ", else: print " ", else: print " ", print "\n"
運行結果:
輸入行數:
*
* *
* *
* *
* * * * *