欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

python將字符串中數(shù)字提取出來然后求和的示例-創(chuàng)新互聯(lián)

這篇文章將為大家詳細講解有關python將字符串中數(shù)字提取出來然后求和的示例,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

創(chuàng)新互聯(lián)是一家專業(yè)提供莘縣企業(yè)網(wǎng)站建設,專注與做網(wǎng)站、成都網(wǎng)站制作、HTML5建站、小程序制作等業(yè)務。10年已為莘縣眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設計公司優(yōu)惠進行中。

因工作原因,很久沒有學習python知識了,感覺都快忘記了,前天看到一個練習題,如何將字符串中的數(shù)字提取出來,然后求和呢?下面我來解釋一下如何通過python代碼來實現(xiàn)。

題目:字符串43...3y2.f67se2.666. 將其中的所有數(shù)字提取出來然后求和

思考:

1、字符串中包含了字母和數(shù)字和小數(shù)點,怎么取出來比較呢?

2、小數(shù)點連續(xù)有很多個的時候怎么處理?

3、最后取出來的數(shù)該怎么求和?

4、最后一個是小數(shù)點該怎么辦?

解題思路:

1、首先通過循環(huán)遍歷去將字符串中的數(shù)字取出來

2、去判斷取出來的數(shù)是數(shù)字還是字母還是小數(shù)點

3、多個小數(shù)點的數(shù)要去掉

4.取出來結果是 43 3 2 67 2.666

源代碼實現(xiàn)過程:

str= "43...3y2.f67se2.666. "
sum = 0
number = ""
is_num ="0123456789" #定義是否是數(shù)字
is_has_float = False #定義是否是小數(shù)點
isstart = False #定義是否是數(shù)字開始的標記變量
for a in str: #將數(shù)字循環(huán)遍歷
 if a in is_num:      #判斷取出來的數(shù)字是否是數(shù)字
  if isstart==True:
   number = number+a
  else:
   number = number+a
   isstart=True
  continue
 if a=='.':       #判斷取出來的數(shù)字是否是小數(shù)點
  if isstart==True:    #判斷前一個是否是數(shù)字
   if is_has_float == True:
    pass
   else:
    is_has_float = True
    number = number+a
    continue
 if isstart == True: #當一個數(shù)字遍歷完了,就要求和,現(xiàn)在取出的數(shù)字格式的字符串,不是整形,所以6+7 = 67
  print(number.strip('.')) #strip去掉最后一個小數(shù)點
  sum = sum+float(number.strip('.'))
  #前一個數(shù)字取完了之后,初始化,
  number = ""
  isstart = False
  is_has_float = False
if isstart == True: #判斷結尾是否是數(shù)字
 print(number.strip("."))
 sum = sum+float(number.strip("."))
print(sum)

大致的流程是這樣的:

先定義好空的對象,用于存放取出來的數(shù)字,和是否是數(shù)字和小數(shù)點,然后在通過取出來的數(shù)字進入循環(huán)里面判斷屬于什么,比如第一個,取出來是4,第9行,判斷4是不是屬于定義的數(shù)字里面的值,屬于就進去第一個if里面,在去判斷number這個對象里面的值首個字母是不是數(shù)字,因為剛開始是空的,所以程序會到13行,最后將4添加進number里面,第二次遍歷,取3,3是數(shù)字,進9行,然后第10行是判斷number里面的值是不是數(shù)字,是,就添加進去,然后number就變成43了,這里說下字符串相加是拼接在一起的不是整形,第三個遍歷添加的取的是小數(shù)點,進去小數(shù)點的判斷里面,也就是16行,然后也是判斷number值第一個是不是數(shù)字,是就進入18行,18行的判斷是判斷number里面有沒有小數(shù)點,有就結束,沒有就添加進去。

所以現(xiàn)在number變成43.了,然后繼續(xù)遍歷第4個,也是小數(shù)點,這時候就會進去18行,已經(jīng)存在小數(shù)點了,pass結束,小數(shù)點后面肯定是接數(shù)字不是其他字符的,就是1.2啊這些 不會是1..2這樣,所以程序會進24行,判斷第一個是不是數(shù)字,然后去掉這個數(shù)字最后一個小數(shù)點,然后添加進去,重置初始化。

等于是剛才number是43..了,但這是不對的,所以去掉最后一個小數(shù)點就是43.了。但求和的時候用了浮點型轉換,所以就會默認補0,變成43.0,后面因為取出的第4位是小數(shù)點,43..組不成一個正常的數(shù)字了,除非第四個繼續(xù)是數(shù)字就可以繼續(xù)添加,說明之前一個數(shù)已經(jīng)取完了,所以要重置初始化,然后依次繼續(xù)取后面的數(shù)字。最后求和。

當取出來是字母的時候,不屬于判斷里面的任意一個,這個時候會被直接過濾掉。

其實不難,但要心細,考慮到多種場景

補充知識:python實現(xiàn)計算字符串中的整數(shù)的總和

題目描述:隨便輸入一串字符串

例如:

輸入:

‘a(chǎn)d23dsf34#'

目的:計算 23+34 的和

輸出:

57

'''
@destination 計算字符串中整數(shù)的和
method:將字符串中的字母同意替換成一個字符然后分隔就可以得到整數(shù)
這里面用到的isdigit函數(shù)是判斷字符串是否是數(shù)字
'''
def cacul(a):
 sum=0#用來存放總和
 c=[]
 for i in a:
  if i.isdigit()==False:
   c.append(i)

 for i in c:
  a=a.replace(i,',')
 a=a.split(',')
 print(a)
 for i in a:
  if i.isdigit()==True:
   sum=sum+int(i)
 return sum

a='1a2b3c4d5f6g'
print(cacul(a))

運行結果為:

python將字符串中數(shù)字提取出來然后求和的示例

關于“python將字符串中數(shù)字提取出來然后求和的示例”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

本文題目:python將字符串中數(shù)字提取出來然后求和的示例-創(chuàng)新互聯(lián)
轉載來源:http://chinadenli.net/article42/ccgohc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作響應式網(wǎng)站動態(tài)網(wǎng)站云服務器ChatGPT靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設計