中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在Python中實現for循環

發布時間:2021-04-01 16:26:38 來源:億速云 閱讀:148 作者:Leah 欄目:開發技術

如何在Python中實現for循環?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

for 循環的語法格式如下:

for 迭代變量 in 字符串|列表|元組|字典|集合:
代碼塊

格式中,迭代變量用于存放從序列類型變量中讀取出來的元素,所以一般不會在循環中對迭代變量手動賦值;代碼塊指的是具有相同縮進格式的多行代碼(和 while 一樣),由于和循環結構聯用,因此代碼塊又稱為循環體。

for 循環語句的執行流程如圖 1 所示。

如何在Python中實現for循環

圖 1 for 循環語句的執行流程圖

例如:

name = '張三'
#變量name,逐個輸出各個字符
for ch in name:
  print(ch)

運行結果為:


可以看到,使用 for 循環遍歷 “張三” 字符串的過程中,迭代變量 ch 先后被賦值為‘張'和‘三',并代入循環體中運行,只不過例子中的循環體比較簡單,只有一行輸出代碼。

for 進行數值循環

在使用 for 循環時,最基本的應用就是進行數值循環。比如說,想要實現從 1 到 100 的累加,可以執行如下代碼:

print("計算 1+2+...+100 的結果為:")
#保存累加結果的變量
result = 0
#逐個獲取從 1 到 100 這些值,并做累加操作
for i in range(101):
  result += i
print(result)

運行結果為:

計算 1+2+...+100 的結果為:
5050

上面代碼中,使用了 range() 函數,此函數是 Python 內置的函數,用于生成一系列連續的整數,多用于 for 循環中。

range() 函數的語法格式如下:

range(start,end,step)

此函數中各參數的含義如下:

  1. start:用于指定計數的起始值,如果省略不寫,則默認從 0 開始。

  2. end:用于指定計數的結束值(不包括此值),此參數不能省略。

  3. step:用于指定步長,即兩個數之間的間隔,如果省略,則默認步長為 1。

總之,在使用 range() 函數時,如果只有一個參數,則表示指定的是 end;如果有兩個參數,則表示指定的是 start 和 end。

大家也可以根據需要寫代碼測試一下。

例如:

print("輸出10 以內的所有奇數:")
for i in range(1,10,2):
 print(i,end=' ')

運行結果為:

輸出10 以內的所有奇數:
1 3 5 7 9

在 Python 2.x 中,除提供 range() 函數外,還提供了一個 xrange() 函數,它可以解決 range() 函數不經意間耗掉所有可用內存的問題。但在 Python 3.x 中,已經將 xrange() 更名為 range() 函數,并刪除了老的 xrange() 函數。

for 循環遍歷列表和元組

在使用 for 循環遍歷列表和元組時,列表或元組有幾個元素,for 循環的循環體就執行幾次,針對每個元素執行一次,迭代變量會依次被賦值為元素的值。

如下代碼使用 for 循環遍歷元組:

a_tuple = ('crazyit', 'fkit', 'Charlie')
for ele in a_tuple:
  print('當前元素是:', ele)

運行結果為:

當前元素是: crazyit
當前元素是: fkit
當前元素是: Charlie

當然,也可按上面方法來遍歷列表。例如,下面程序要計算列表中所有數值元素的總和、平均值:

src_list = [12, 45, 3.4, 13, 'a', 4, 56, 'crazyit', 109.5]
my_sum = 0
my_count = 0
for ele in src_list:
  # 如果該元素是整數或浮點數
  if isinstance(ele, int) or isinstance(ele, float):
    print(ele)
    # 累加該元素
    my_sum += ele
    # 數值元素的個數加1
    my_count += 1
print('總和:', my_sum)
print('平均數:', my_sum / my_count)

運行結果為:

12
45
3.4
13
4
56
109.5
總和: 242.9
平均數: 34.7

上面程序使用 for 循環遍歷列表的元素,并對幾何元素進行判斷:只有當列表元素是數值(int、float)時,程序才會累加它們,這樣就可以計算出列表中數值元素的總和。

不僅如此,程序中還使用了 Python 的 isinstance() 函數,該函數用于判斷某個變量是否為指定類型的實例,其中前一個參數是要判斷的變量,后一個參數是類型。我們可以在 Python 的交互式解釋器中測試該函數的功能,例如如下運行過程:

>>> isinstance(2,int)
True
>>> isinstance('a',int)
False
>>> isinstance('a',str)
True

從上面的運行過程可以看出,使用 isinstance() 函數判斷變量是否為指定類型非常方便、有效。

如果需要,for 循環也可根據索引來遍歷列表或元組,即只要讓迭代變量取 0 到列表長度的區間,就可通過該迭代變量訪問列表元素。例如如下程序:

a_list = [330, 1.4, 50, 'fkit', -3.5]
# 遍歷0到len(a_list)的范圍
for i in range(0, len(a_list)) :
  # 根據索引訪問列表元素
  print("第%d個元素是 %s" % (i , a_list[i]))

運行結果為:

第0個元素是 330
第1個元素是 1.4
第2個元素是 50
第3個元素是 fkit
第4個元素是 -3.5

for 循環遍歷字典

使用 for 循環遍歷字典其實也是通過遍歷普通列表來實現的。前面在介紹字典時己經提到,字典包含了如下三個方法:

  1. items():返回字典中所有 key-value 對的列表。

  2. keys():返回字典中所有 key 的列表。

  3. values():返回字典中所有 value 的列表。

因此,如果要遍歷字典,完全可以先調用字典的上面三個方法之一來獲取字典的所有 key-value 對、所有 key、所有 value,再進行遍歷。如下程序示范了使用 for 循環來遍歷字典:

my_dict = {'語文': 89, '數學': 92, '英語': 80}
# 通過items()方法遍歷所有key-value對
# 由于items方法返回的列表元素是key-value對,因此要聲明兩個變量
for key, value in my_dict.items():
  print('key:', key)
  print('value:', value)
print('-------------')
# 通過keys()方法遍歷所有key
for key in my_dict.keys():
  print('key:', key)
  # 在通過key獲取value
  print('value:', my_dict[key])
print('-------------')
# 通過values()方法遍歷所有value
for value in my_dict.values():
  print('value:', value)

運行結果為:

key: 語文
value: 89
key: 數學
value: 92
key: 英語
value: 80
-------------
key: 語文
value: 89
key: 數學
value: 92
key: 英語
value: 80
-------------
value: 89
value: 92
value: 80

上面程序通過三個 for 循環分別遍歷了字典的所有 key-value 對、所有 key、所有 value。尤其是通過字典的 items() 遍歷所有的 key-value 對時,由于 items() 方法返回的是字典中所有 key-value 對組成的列表,列表元素都是長度為 2 的元組,因此程序要聲明兩個變量來分別代表 key、value(這也是序列解包的應用)。

假如需要實現一個程序,用于統計列表中各元素出現的次數。由于我們并不清楚列表中包含多少個元素,因此考慮定義一個字典,以列表的元素為 key,該元素出現的次數為 value。程序如下:

src_list = [12, 45, 3.4, 12, 'fkit', 45, 3.4, 'fkit', 45, 3.4]
statistics = {}
for ele in src_list:
  # 如果字典中包含ele代表的key
  if ele in statistics:
    # 將ele元素代表出現次數加1
    statistics[ele] += 1
  # 如果字典中不包含ele代表的key,說明該元素還未出現過
  else:
    # 將ele元素代表出現次數設為1
    statistics[ele] = 1   
# 遍歷dict,打印出各元素的出現次數
for ele, count in statistics.items():
  print("%s的出現次數為:%d" % (ele, count))

運行結果為:

12的出現次數為:2
45的出現次數為:3
3.4的出現次數為:3
fkit的出現次數為:2

python循環-for循環綜合小案例

一、字符串的反轉

# 翻轉字符—將“我是個大好人!我愛我的家”反轉“家的我愛我!人好大個是我”
yuanJu = "我是個大好人!我愛我的家"
result = ""
# 第一步,先拆字
for x in yuanJu:
# 用遍歷出的結果與空字符串相加
  result = x + result
print(result)

二、打印 1—100之間的偶數

# 打印 1—100之間的偶數
# 首先創建一個1—100的集合,利用range函數,生成的半開半閉的區間,所以最后得+1。
num = range(1, 101)
for n in num:
  if n % 2 == 0:
    print(n)
else:
  print("以上數字為1-100之內的偶數")

因為上面的偶數需要包括100,所以range(1,101).

關于如何在Python中實現for循環問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阜南县| 全椒县| 青川县| 绍兴市| 景洪市| 甘泉县| 曲水县| 广河县| 靖安县| 东台市| 临洮县| 大田县| 张掖市| 滕州市| 大关县| 都安| 西华县| 甘孜| 米脂县| 巴彦淖尔市| 忻州市| 金华市| 沁水县| 邯郸市| 连山| 加查县| 游戏| 泽库县| 电白县| 宁阳县| 饶河县| 昆明市| 阳谷县| 阿瓦提县| 兴安县| 察隅县| 怀远县| 临城县| 崇州市| 桐乡市| 巫溪县|