溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

python判斷字符串是不是數(shù)字算法的方法

發(fā)布時(shí)間:2020-07-11 09:23:19 來源:億速云 閱讀:338 作者:清晨 欄目:開發(fā)技術(shù)

小編給大家分享一下python判斷字符串是不是數(shù)字算法的方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

算法1

1、分小數(shù)和整數(shù):如果小數(shù)點(diǎn)個(gè)數(shù)為1,則可能是小數(shù)。如小數(shù)點(diǎn)個(gè)數(shù)為0,則可能是整數(shù)。小數(shù)點(diǎn)個(gè)數(shù)非0也非1,那么就不是數(shù)字。

2、如果是小數(shù),再分正數(shù)和負(fù)數(shù)的情況:如果首位為負(fù)號(hào),則可能是負(fù)小數(shù)。如果首位不為負(fù)號(hào),則可能是正小數(shù)。

1)如果首位為負(fù)號(hào),則去掉負(fù)號(hào)。

2)如果首位不為負(fù)號(hào);或者是首位為負(fù)號(hào),去掉首位負(fù)號(hào)之后。則判斷是否為是否為“.”,如果是,那么就不是數(shù)字,如果不是,就去掉"."

3)再判斷剩下字符是否都在"0123456789"內(nèi),如果不都在則不是數(shù)字,否則就是數(shù)字

3、如果是整數(shù),也同樣分正數(shù)和負(fù)數(shù)的情況。如果首位為負(fù)號(hào),則可能是負(fù)整數(shù),如果首位不為負(fù)號(hào),則可能是正整數(shù)。

1)如果首位誒負(fù)號(hào),則去掉負(fù)號(hào)。

2)如果首位不為負(fù)號(hào);或者是首位為負(fù)號(hào),去掉首位負(fù)號(hào)之后。判斷剩下字符是否都在"0123456789"內(nèi),如果不都在則不是數(shù)字,否則就是數(shù)字

python判斷字符串是不是數(shù)字算法的方法

 #encoding=utf-8
def is_number(s):
  if s.count(".")==1:  #小數(shù)的判斷
    if s[0]=="-":
      s=s[1:]
    if s[0]==".":
      return False
    s=s.replace(".","")
    for i in s:
      if i not in "0123456789":
        return False
    else:        #這個(gè)else與for對(duì)應(yīng)的
      return True
  elif s.count(".")==0:  #整數(shù)的判斷
    if s[0]=="-":
      s=s[1:]
    for i in s:
      if i not in "0123456789":
        return False
    else:
      return True
  else:
    return False
print(is_number("1334345345"))
print(is_number("1.12344565"))
print(is_number("-14344343"))
print(is_number("-1.123456"))
print("**********************")
print(is_number("abc"))
print(is_number("1.32.2"))
print(is_number(".2344"))
print(is_number("1234a"))
print(is_number("--1.1"))
print(is_number("--1abc"))

python判斷字符串是不是數(shù)字算法的方法

算法2

1、判斷首位是否是負(fù)號(hào)或者數(shù)字,如果不是,則不是數(shù)字。如果是,則可能是數(shù)字。

2、判斷"."和"-"的個(gè)數(shù)是否都小于等于1,如果不是,則不是數(shù)字,如果是,則可能是數(shù)字。

3、去掉"."和"-" 。

4、判斷剩下的字符是否都在"0123456789"內(nèi),如果不都在則不是數(shù)字,否則就是數(shù)字

python判斷字符串是不是數(shù)字算法的方法

#encoding=utf-8
def is_number(s):
  if s[0]=="-" or s[0] in "0123456789":
    if s.count(".")<=1 and s.count("-")<=1:
      s=s.replace("-","").replace(".","")
      #print (s)
      for i in s:
        if i not in "0123456789":
          return False
      else:        #這個(gè)else與for對(duì)應(yīng)
        return True
    else:
      return False 
  else:
    return False
print(is_number("1334345345"))
print(is_number("1.12344565"))
print(is_number("-14344343"))
print(is_number("-1.123456"))
print("**********************")
print(is_number("abc"))
print(is_number("1.32.2"))
print(is_number(".2344"))
print(is_number("1234a"))
print(is_number("--1.1"))
print(is_number("--1abc"))

python判斷字符串是不是數(shù)字算法的方法

看完了這篇文章,相信你對(duì)python判斷字符串是不是數(shù)字算法的方法有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI