創(chuàng)新互聯(lián)www.cdcxhl.cn八線動態(tài)BGP香港云服務(wù)器提供商,新人活動買多久送多久,劃算不套路!
創(chuàng)新互聯(lián)專業(yè)提供鄭州服務(wù)器托管服務(wù),為用戶提供五星數(shù)據(jù)中心、電信、雙線接入解決方案,用戶可自行在線購買鄭州服務(wù)器托管服務(wù),并享受7*24小時金牌售后服務(wù)。小編給大家分享一下python判斷字符串是不是數(shù)字算法的方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!
算法1
1、分小數(shù)和整數(shù):如果小數(shù)點個數(shù)為1,則可能是小數(shù)。如小數(shù)點個數(shù)為0,則可能是整數(shù)。小數(shù)點個數(shù)非0也非1,那么就不是數(shù)字。
2、如果是小數(shù),再分正數(shù)和負數(shù)的情況:如果首位為負號,則可能是負小數(shù)。如果首位不為負號,則可能是正小數(shù)。
1)如果首位為負號,則去掉負號。
2)如果首位不為負號;或者是首位為負號,去掉首位負號之后。則判斷是否為是否為“.”,如果是,那么就不是數(shù)字,如果不是,就去掉"."
3)再判斷剩下字符是否都在"0123456789"內(nèi),如果不都在則不是數(shù)字,否則就是數(shù)字
3、如果是整數(shù),也同樣分正數(shù)和負數(shù)的情況。如果首位為負號,則可能是負整數(shù),如果首位不為負號,則可能是正整數(shù)。
1)如果首位誒負號,則去掉負號。
2)如果首位不為負號;或者是首位為負號,去掉首位負號之后。判斷剩下字符是否都在"0123456789"內(nèi),如果不都在則不是數(shù)字,否則就是數(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: #這個else與for對應(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"))