欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python提取字符串中的數(shù)字的實(shí)現(xiàn)

 更新時間:2023年10月15日 16:09:41   作者:趙孝正  
本文主要介紹了python提取字符串中的數(shù)字的實(shí)現(xiàn),主要介紹了幾種常見的方法,具有一定的參考價值,感興趣的可以了解一下

一、isdigit() 函數(shù)

isdigit() 函數(shù)是檢測輸入字符串是否只由數(shù)字組成。如果字符串只包含數(shù)字則返回 True 否則返回 False。

dream = "123456"
print(dream.isdigit())  # 返回:True

dream = "123abc456"
print(dream.isdigit())  # 返回:False

dream = 'abcd'
print(dream.isdigit())  # 返回:False

# '120m' 拆為 '120'和'm',不加key=lambda x: x.isdigit()的話,會拆成['1', '2', '0', 'm']
from itertools import groupby
str = '120m'
ret = [''.join(list(g)) for k, g in groupby(str, key=lambda x: x.isdigit())]
# 輸出['120', 'm']
[k for k, g in groupby('150m', lambda x: x.isdigit())]
Out[8]: [True, False]
[k for k, g in groupby('150m')]
Out[9]: ['1', '5', '0', 'm']
[g for k, g in groupby('150m', lambda x: x.isdigit())]
Out[10]: [<itertools._grouper at 0x214eeb877f0>, <itertools._grouper at 0x214eeb87820>]

[list(g) for k, g in groupby('150m', lambda x: x.isdigit())]
Out[11]: [['1', '5', '0'], ['m']]

二、filter() 函數(shù)

說明:filter() 函數(shù)用于過濾序列,過濾掉不符合條件的元素,返回一個迭代器對象;

如果要轉(zhuǎn)換為列表,可以使用 list() 來轉(zhuǎn)換。

該接收兩個參數(shù),第一個為函數(shù),第二個為序列,序列的每個元素作為參數(shù)傳遞給函數(shù)進(jìn)行判斷,然后返回 True 或 False,最后將返回 True 的元素放到新列表中。

語法:

filter(function, iterable)

1、過濾出列表中的所有奇數(shù):

def is_odd(n):
    return n % 2 == 1
 
tmplist = filter(is_odd, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
newlist = list(tmplist)
print(newlist)

2、過濾出列表中的所有偶數(shù):

l = [x for x in range(10)]
print(list(filter(lambda x : x%2 == 0, l)))

3、過濾出1~100中平方根是整數(shù)的數(shù):

import math
def is_sqr(x):
    return math.sqrt(x) % 1 == 0
 
tmplist = filter(is_sqr, range(1, 101))
newlist = list(tmplist)
print(newlist)

# [1, 3, 5, 7, 9]

4、刪除1-20中素?cái)?shù)

L = range(1, 21)

def isprimer(n):
    flag = 1
    for i in range(2, n):
        if n % i == 0:
            flag = 0
    if flag == 0:
        return n

print(list(filter(isprimer, L)))
# [4, 6, 8, 9, 10, 12, 14, 15, 16, 18, 20]

5、去除空格和空值

def not_empty(s):
  return s and s.strip()

filter(not_empty, ['A', '', 'B', None, 'C', ' '])

6、高階運(yùn)用

def _odd_iter():
    n = 1
    while True:
        n = n + 2
        yield n
        
def _not_divisible(n): 
    return lambda x : x%n>0
 
def primes():
    yield 2
    it = _odd_iter()
    ftr = filter(_not_divisible(2), it) #1
    while True:
        n = next(ftr )        #2
        yield n                
        ftr = filter(_not_divisible(n), ftr ) #3
        
for n in primes():
    if n < 20:
        print('now:',n)
    else:
        break
輸出:
now: 2
now: 3
now: 5
now: 7
now: 11
now: 13
now: 17
now: 19

三、提取一段字符串中的數(shù)字

列表轉(zhuǎn)字符串

number = ['12', '333', '4']
number_ = "".join(number)    # 列表轉(zhuǎn)字符串
print(number_)    # 123334
a = "".join(list(filter(str.isdigit, '123ab45')))
print(a)
# 返回12345

b = list(filter(str.isdigit, '123ab45'))
print(b)
# 返回['1', '2', '3', '4', '5']
time_ = "2019年09月04日 11:00"
time_filter = filter(str.isdigit, time_)

print(time_filter)           # <filter object at 0x0000019358731BE0>
print(type(time_filter))     # <class 'filter'>
time_list = list(time_filter)       # ['2', '0', '1', '9', '0', '9', '0', '4', '1', '1', '0', '0']
time_str = "".join(time_list)       # 轉(zhuǎn)為str    201909041100
time_int = int(time_str)            # 轉(zhuǎn)為int    201909041100

利用正則表達(dá)式

import re
str_ = "12今天333天氣4不錯"
number = re.findall("\d+",str_)    # 輸出結(jié)果為列表
print(number)
 
# 輸出結(jié)果:['12', '333', '4']

四、匹配指定字符串開頭的數(shù)字

例如下面的string:

tensorflow:Final best valid 0 loss=0.20478513836860657 norm_loss=0.767241849151384 roc=0.8262403011322021 pr=0.39401692152023315 calibration=0.9863265752792358 rate=0.0

提取 calibration=0.9863265752792358 .

# 匹配“calibration=”后面的數(shù)字
pattern = re.compile(r'(?<=calibration=)\d+\.?\d*')
pattern.findall(string)

# ['0.9863265752792358']

到此這篇關(guān)于python提取字符串中的數(shù)字的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)python提取字符串中數(shù)字內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • Python GUI編程之tkinter 關(guān)于 ttkbootstrap 的使用詳解

    Python GUI編程之tkinter 關(guān)于 ttkbootstrap 的使用

    ttkbootstrap 是一個基于 tkinter 的界面美化庫,使用這個工具可以開發(fā)出類似前端 bootstrap 風(fēng)格的 tkinter 桌面程序,這篇文章主要介紹了Python GUI編程之tkinter 關(guān)于 ttkbootstrap 的使用詳解,需要的朋友可以參考下
    2022-03-03
  • python分?jǐn)?shù)表示方式和寫法

    python分?jǐn)?shù)表示方式和寫法

    在本篇文章里小編給大家整理的是關(guān)于python分?jǐn)?shù)怎么表示的相關(guān)知識點(diǎn)內(nèi)容,有需要的朋友們學(xué)習(xí)下吧。
    2019-06-06
  • python實(shí)現(xiàn)矩陣的示例代碼

    python實(shí)現(xiàn)矩陣的示例代碼

    本文主要介紹了python實(shí)現(xiàn)矩陣的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • 淺析Python中return和finally共同挖的坑

    淺析Python中return和finally共同挖的坑

    最近在工作中遇到一個坑,發(fā)現(xiàn)這個坑居然存在于return和finally,所以覺著有必要總結(jié)分享一下,下面這篇文章主要介紹了關(guān)于Python中return和finally共同挖的坑,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-08-08
  • pandas按行按列遍歷Dataframe的三種方式小結(jié)

    pandas按行按列遍歷Dataframe的三種方式小結(jié)

    本文主要介紹了pandas按行按列遍歷Dataframe,主要介紹了三種方法,具有一定的參考價值,感興趣的可以了解一下
    2023-11-11
  • Python基于pygame實(shí)現(xiàn)的彈力球效果(附源碼)

    Python基于pygame實(shí)現(xiàn)的彈力球效果(附源碼)

    這篇文章主要介紹了Python基于pygame實(shí)現(xiàn)的彈力球效果,涉及pygame圖形動態(tài)操作的相關(guān)的技巧,并附帶了完整的源碼供讀者下載參考,需要的朋友可以參考下
    2015-11-11
  • python二分法實(shí)現(xiàn)實(shí)例

    python二分法實(shí)現(xiàn)實(shí)例

    這篇文章主要介紹了python二分法的實(shí)現(xiàn)代碼,大家可以參考使用
    2013-11-11
  • numpy多維數(shù)組索引問題

    numpy多維數(shù)組索引問題

    這篇文章主要介紹了numpy多維數(shù)組索引的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Python學(xué)習(xí)之異常中的finally使用詳解

    Python學(xué)習(xí)之異常中的finally使用詳解

    這篇文章主要為大家介紹一下Python異常語法中的另一個成員—finally,通過學(xué)習(xí)finally,可以幫助我們更好的處理異常,快來跟隨小編一起學(xué)習(xí)一下吧
    2022-03-03
  • PyQt5 QLineEdit輸入的子網(wǎng)字符串校驗(yàn)QRegExp實(shí)現(xiàn)

    PyQt5 QLineEdit輸入的子網(wǎng)字符串校驗(yàn)QRegExp實(shí)現(xiàn)

    這篇文章主要介紹了PyQt5 QLineEdit輸入的子網(wǎng)字符串校驗(yàn)QRegExp實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04

最新評論