計算字元串中所有數字的和,字元串中有數字和字母組合而成
如果出現連續數字,按照一個數操作
具體解釋在代碼行裡:
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) #調用函數
運作結果:

轉載于:https://www.cnblogs.com/ilovezzh/p/9380155.html