詳解Python3中字符串中的數(shù)字提取方法
逛到一個有意思的博客在里面看到一篇關(guān)于ValueError: invalid literal for int() with base 10錯誤的解析,針對這個錯誤,博主已經(jīng)給出解決辦法,使用的是re.sub 方法
totalCount = '100abc'
totalCount = re.sub("\D", "", totalCount)
但是沒有說明什么含義,于是去查了其他的資料,做一下記錄:
在Python3.5.2 官方文檔re模塊中sub函數(shù)的定義是:
re.sub(pattern, repl, string, count=0, flags=0)
在字符串 string 中找到匹配正則表達(dá)式 pattern 的所有子串,用另一個字符串 repl 進(jìn)行替換。如果沒有找到匹配 pattern 的串,則返回未被修改的 string。Repl 既可以是字符串也可以是一個函數(shù)。
由此可分析上面使用的語句的含義:在'100abc'這個字符串中找到非數(shù)字的字符(正則表達(dá)式中'\D'表示非數(shù)字),并用""替換,然后返回的就是只剩下數(shù)字的字符串。
>>> totalCount = '100abc'
>>> totalCount = re.sub("\D", "", totalCount)
>>> print(totalCount)
100
>>> type(totalCount)
<class 'str'>
好吧,以上說明完畢,不過其實我想到的是我爬取知乎所關(guān)注的問答時,所遇到的類似的問題:
answer_num_get = soup.find('h3', {'id': 'zh-question-answer-num'}) # 答案數(shù)量:32 個回答
if answer_num_get is not None:
answer_num = int(answer_num_get.split()[0])
n = answer_num // 10
其中第三行之所以能用int(),是因為string.split()[0]將answer_num_get的值“32 個回答”提取出數(shù)字(注:32后面有一個空格,在這里非常重要,因為知乎上抓取回來的這個元素就是)
split()的定義 str.split(sep=None, maxsplit=-1)
>>> import string
>>> a = "32 個答案"
>>> 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()的第一個參數(shù)是分隔符,如果什么都不填就是默認(rèn)是以空格來分隔。
第一種方法需要用到正則表達(dá)式,第二種方法則需要有分隔符(我猜是不是這個原因,在原網(wǎng)頁上總答案數(shù)的數(shù)字后有個空格存在)。 這兩種方法都有點局限性,不知道是否有更好的方法來分離字符串中的數(shù)字。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
matplotlib交互式數(shù)據(jù)光標(biāo)mpldatacursor的實現(xiàn)
這篇文章主要介紹了matplotlib交互式數(shù)據(jù)光標(biāo)mpldatacursor的實現(xiàn) ,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
利用Python內(nèi)置庫實現(xiàn)創(chuàng)建命令行應(yīng)用程序
Python?有一個叫做argparse的內(nèi)置庫,可以用它來創(chuàng)建一個命令行界面。本文將詳解如何利用argparse實現(xiàn)創(chuàng)建一個命令行應(yīng)用程序,需要的可以參考一下2022-06-06
Python之tkinter組合框Combobox用法及說明
這篇文章主要介紹了Python之tkinter組合框Combobox用法及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05
解決Python中由于logging模塊誤用導(dǎo)致的內(nèi)存泄露
這篇文章主要介紹了解決Python中由于logging模塊誤用導(dǎo)致的內(nèi)存泄露,針對由于過多的UDP連接所產(chǎn)生的問題,需要的朋友可以參考下2015-04-04
python將YUV420P文件轉(zhuǎn)PNG圖片格式的兩種方法
這篇文章主要介紹了python將YUV420P文件轉(zhuǎn)PNG圖片格式的兩種方法,幫助大家更好的理解和使用python,感興趣的朋友可以了解下2021-01-01

