運行結果: ...
計算字元串中所有數字的和,字元串中有數字和字母組合而成
如果出現連續數字,按照一個數操作
具體解釋在代碼行里:
def sum_str(str1): len1=len(str1) #首先將字元串str1的長度賦值給len1 sum = n = 0 #建立一個值為0的空變數sun #建立一個值為0的空變數n for i in range(len1): #用i來遍歷字元串的長度 if 49 <= ord(str1[i]) <= 57: #判斷字元ascii碼是否在數字ascii值範圍內 n = n * 10 #n *= 10 n = int(str1[i]) + n #n += int(str1[i]) else: sum = n + sum #sum += n n = 0 # 上面6行代碼的意思是從0下標開始,遍歷字元串,如果是數字,用n加上其數字, #執行邏輯是,碰見一個數字,用n加上,如果下一個還是數字,就將上一個數字乘10加這個數字,依次迴圈 #比如:連續數字df123asd = ((1*10+2)*10)+3 #如果不是數字,就將n值加到變數sum中,保存,並且將n重新賦值為0,再次進入for迴圈,(sun只在碰見字母的時候出現,把數字之前的數字的值收集起來) # 下次再碰到數字(滿足if條件),迴圈(if)條件下麵的邏輯 sum = n +sum print(sum) str1 = "b532x2x3c4b5" sum_str(str1) #調用函數
運行結果: