詳解Python3中字符串中的數(shù)字提取方法
逛到一個(gè)有意思的博客在里面看到一篇關(guān)于ValueError: invalid literal for int() with base 10錯(cuò)誤的解析,針對(duì)這個(gè)錯(cuò)誤,博主已經(jīng)給出解決辦法,使用的是re.sub 方法
totalCount = '100abc' totalCount = re.sub("\D", "", totalCount)
但是沒(méi)有說(shuō)明什么含義,于是去查了其他的資料,做一下記錄:
在Python3.5.2 官方文檔re模塊中sub函數(shù)的定義是:
re.sub(pattern, repl, string, count=0, flags=0)
在字符串 string 中找到匹配正則表達(dá)式 pattern 的所有子串,用另一個(gè)字符串 repl 進(jìn)行替換。如果沒(méi)有找到匹配 pattern 的串,則返回未被修改的 string。Repl 既可以是字符串也可以是一個(gè)函數(shù)。
由此可分析上面使用的語(yǔ)句的含義:在'100abc'這個(gè)字符串中找到非數(shù)字的字符(正則表達(dá)式中'\D'表示非數(shù)字),并用""替換,然后返回的就是只剩下數(shù)字的字符串。
>>> totalCount = '100abc' >>> totalCount = re.sub("\D", "", totalCount) >>> print(totalCount) 100 >>> type(totalCount) <class 'str'>
好吧,以上說(shuō)明完畢,不過(guò)其實(shí)我想到的是我爬取知乎所關(guān)注的問(wèn)答時(shí),所遇到的類似的問(wèn)題:
answer_num_get = soup.find('h3', {'id': 'zh-question-answer-num'}) # 答案數(shù)量:32 個(gè)回答 if answer_num_get is not None: answer_num = int(answer_num_get.split()[0]) n = answer_num // 10
其中第三行之所以能用int(),是因?yàn)閟tring.split()[0]將answer_num_get的值“32 個(gè)回答”提取出數(shù)字(注:32后面有一個(gè)空格,在這里非常重要,因?yàn)橹跎献ト』貋?lái)的這個(gè)元素就是)
split()的定義 str.split(sep=None, maxsplit=-1)
>>> import string >>> a = "32 個(gè)答案" >>> b = a.split()[0] >>> print(b) 32 >>> type(b) <class 'str'> >>> c = '1,2,3' >>> c.split(',') ['1', '2', '3'] >>> c.split(',')[0] '1' >>> c.split(',')[1] '2' >>>
由此可看出split()的第一個(gè)參數(shù)是分隔符,如果什么都不填就是默認(rèn)是以空格來(lái)分隔。
第一種方法需要用到正則表達(dá)式,第二種方法則需要有分隔符(我猜是不是這個(gè)原因,在原網(wǎng)頁(yè)上總答案數(shù)的數(shù)字后有個(gè)空格存在)。 這兩種方法都有點(diǎn)局限性,不知道是否有更好的方法來(lái)分離字符串中的數(shù)字。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
解決usageerror: line magic function "
這篇文章主要介紹了解決usageerror: line magic function "%%time" not found問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01Python 實(shí)現(xiàn)兩個(gè)列表里元素對(duì)應(yīng)相乘的方法
今天小編就為大家分享一篇Python 實(shí)現(xiàn)兩個(gè)列表里元素對(duì)應(yīng)相乘的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-11-11Python對(duì)象轉(zhuǎn)JSON字符串的方法
這篇文章主要介紹了Python對(duì)象轉(zhuǎn)JSON字符串的方法,涉及Python基于json模塊實(shí)現(xiàn)json轉(zhuǎn)換的實(shí)現(xiàn)技巧,非常簡(jiǎn)便易懂,需要的朋友可以參考下2016-04-04Python Tkinter模塊實(shí)現(xiàn)時(shí)鐘功能應(yīng)用示例
這篇文章主要介紹了Python Tkinter模塊實(shí)現(xiàn)時(shí)鐘功能,結(jié)合實(shí)例形式分析了Tkinter模塊結(jié)合time模塊實(shí)現(xiàn)的時(shí)鐘圖形繪制與計(jì)時(shí)功能相關(guān)操作技巧,需要的朋友可以參考下2018-07-07Python實(shí)現(xiàn)emoji表情的簡(jiǎn)單方法
“表情包”是一種利用圖片來(lái)表示感情的一種方式。下面這篇文章主要給大家介紹了關(guān)于Python實(shí)現(xiàn)emoji表情的簡(jiǎn)單方法,需要的朋友可以參考下2021-05-05python四種出行路線規(guī)劃的實(shí)現(xiàn)
路徑規(guī)劃中包括步行、公交、駕車、騎行等不同方式,今天借助高德地圖web服務(wù)api,實(shí)現(xiàn)出行路線規(guī)劃。感興趣的可以了解下2021-06-06已安裝Pytorch卻提示no?moudle?named?'torch'(沒(méi)有名稱為torch
這篇文章主要給大家介紹了關(guān)于已安裝Pytorch卻提示no?moudle?named?'torch'(沒(méi)有名稱為torch的模塊)的相關(guān)資料,當(dāng)提示"No module named 'torch'"時(shí),可能是由于安裝的Pytorch版本與當(dāng)前環(huán)境不匹配導(dǎo)致的,需要的朋友可以參考下2023-11-11Python偏函數(shù)Partial function使用方法實(shí)例詳解
這篇文章主要介紹了Python偏函數(shù)Partial function使用方法實(shí)例詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06