国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

詳解python正則表達式數(shù)量詞

python爬蟲知識分享 ? 來源:python爬蟲知識分享 ? 作者:python爬蟲知識分享 ? 2022-03-18 16:05 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

這部分理解一下數(shù)量詞,為什么要用數(shù)量詞,想想都知道,如果你要匹配幾十上百的字符時,難道你要一個一個的寫,所以就出現(xiàn)了數(shù)量詞。

數(shù)量詞的詞法是:{min,max} 。min 和 max 都是非負整數(shù)。如果逗號有而 max 被忽略了,則 max 沒有限制。如果逗號和 max 都被忽略了,則重復 min 次。比如,\b[1-9][0-9]{3}\b,匹配的是 1000 ~ 9999 之間的數(shù)字( “\b” 表示單詞邊界),而 \b[1-9][0-9]{2,4}\b,匹配的是一個在 100 ~ 99999 之間的數(shù)字。

下面看一個實例,匹配出字符串中 4 到 7 個字母的英文

import re

a = 'java*&39android##@@python'

# 數(shù)量詞

findall = re.findall('[a-z]{4,7}', a)
print(findall)

輸出結果:

['java', 'android', 'python']

注意,這里有貪婪和非貪婪之分。那么我們先看下相關的概念:

貪婪模式:它的特性是一次性地讀入整個字符串,如果不匹配就吐掉最右邊的一個字符再匹配,直到找到匹配的字符串或字符串的長度為 0 為止。它的宗旨是讀盡可能多的字符,所以當讀到第一個匹配時就立刻返回。

懶惰模式:它的特性是從字符串的左邊開始,試圖不讀入字符串中的字符進行匹配,失敗,則多讀一個字符,再匹配,如此循環(huán),當找到一個匹配時會返回該匹配的字符串,然后再次進行匹配直到字符串結束。

上面例子中的就是貪婪的,如果要使用非貪婪,也就是懶惰模式,怎么呢?

如果要使用非貪婪,則加一個 ? ,上面的例子修改如下:

import re

a = 'java*&39android##@@python'

# 貪婪與非貪婪

re_findall = re.findall('[a-z]{4,7}?', a)
print(re_findall)

輸出結果如下:

['java', 'andr', 'pyth']

從輸出的結果可以看出,android 只打印除了 andr ,Python 只打印除了 pyth ,因為這里使用的是懶惰模式。

當然,還有一些特殊字符也是可以表示數(shù)量的,比如:

?:告訴引擎匹配前導字符 0 次或 1 次

+:告訴引擎匹配前導字符 1 次或多次

*:告訴引擎匹配前導字符 0 次或多次

把這部分的知識點總結一下,就是下面這個表了:

貪 婪 惰 性 描 述
? ?? 零次或一次出現(xiàn),等價于{0,1}
+ +? 一次或多次出現(xiàn) ,等價于{1,}
* *? 零次或多次出現(xiàn) ,等價于{0,}
{n} {n}? 恰好 n 次出現(xiàn)
{n,m} {n,m}? 至少 n 次枝多 m 次出現(xiàn)
{n,} {n,}? 至少 n 次出現(xiàn)

審核編輯:湯梓紅
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 字符串
    +關注

    關注

    1

    文章

    596

    瀏覽量

    23166
  • python
    +關注

    關注

    57

    文章

    4876

    瀏覽量

    90039
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    布爾表達式及范圍檢查

    一個常用的布爾表達式是用于判斷變量是否位于某個范圍內(nèi), 例如,檢查一個圖形坐標是否位于一個窗口內(nèi): bool PointInRectangelArea (Point p, Rectangle
    發(fā)表于 12-12 07:08

    C語言的分支結構介紹

    1.簡單if語句 C語言中的分支結構語句中的if條件語句。 簡單if語句的基本結構如下: 代碼語言:javascript if(表達式) { 執(zhí)行代碼塊; } 其語義是:如果表達式的值為真,則執(zhí)行其后的語句,否則不執(zhí)行該語句。 注意:if()后面沒有分號,直
    發(fā)表于 11-25 07:48

    第4章 C語言基礎以及流水燈的實現(xiàn)(4.5 4.6)

    (表達式) ? ? ? ?{ ? ? ? ? ? ?循環(huán)體語句; ? ? ? ?} 在C語言里,通常“表達式”符合條件叫做真,不符合條件,叫做假。比如前邊i while(表達式)這個括號里的
    的頭像 發(fā)表于 11-06 11:21 ?356次閱讀

    inline ASM(內(nèi)聯(lián)匯編)的細節(jié)分享

    表達式指定了數(shù)字9作為 操作約束的話,那么說明Output操作表達式數(shù)量已經(jīng)至少為10個了,那么再加上這個Input操作表達式,則至少為11個了,以及超出GCC的限制。 modifi
    發(fā)表于 10-31 09:11

    I1電流計算對不對?怎么推導不出來I1的表達式是圖中那樣

    I1電流計算對不對?怎么推導不出來I1的表達式是圖中那樣
    發(fā)表于 09-28 18:01

    labview如何使用VISA串口資源查找的正則表達式提取串口的資源名稱?

    如圖,如何利用VISA資源查找的正則表達式從很多串口當中提取想要的目標串口(Quectel USB AT Port這個串口)?
    發(fā)表于 07-07 17:20

    基礎篇3:掌握Python中的條件語句與循環(huán)

    不同的條件執(zhí)行不同的代碼塊。Python中的條件語句主要使用if、elif(else if的縮寫)和else關鍵字。 if語句 最簡單的條件語句是if語句,它的工作方式如下: 復制代碼 if 條件表達式
    發(fā)表于 07-03 16:13

    Cubeide1.18.1在線調試改變\"現(xiàn)場表達式\"中的值提示找不到地址,為什么?

    Cubeide1.18.1在線調試時,在\"現(xiàn)場表達式\"中添加全局變量,然后改變其數(shù)值,Console窗口提示: Failed to read all registers
    發(fā)表于 06-12 06:50

    《ESP32S3 Arduino開發(fā)指南》第三章 C/C++語言基礎

    基礎,由于篇幅有限,在此僅對C/C++語言基礎進行簡單介紹。本章將分為如下9個小節(jié):3.1 數(shù)據(jù)類型3.2 運算符3.3 表達式3.4 數(shù)組3.5 字符串3.6 注釋3.7 順序結構3.8 選擇結構
    發(fā)表于 06-10 09:20

    Cubeide1.18.1在線調試改變\"現(xiàn)場表達式\"中的值提示找不到地址是怎么回事?

    Cubeide1.18.1在線調試時,在\"現(xiàn)場表達式\"中添加全局變量,然后改變其數(shù)值,Console窗口提示: Failed to read all registers
    發(fā)表于 06-10 08:26

    干貨分享 | 零基礎上手!TSMaster圖形信號表達式實操指南

    TSMaster軟件支持在圖形里面的信號表達式功能,主要用于多信號表達式運算和顯示的場景。本文將以A2L中的標定變量為例,介紹如何使用圖形中的信號表達式功能進行多信號的后處理運算和顯示。本文關鍵詞
    的頭像 發(fā)表于 06-06 20:03 ?889次閱讀
    干貨分享 | 零基礎上手!TSMaster圖形信號<b class='flag-5'>表達式</b>實操指南

    Cubeide1.18.1在線調試改變\"現(xiàn)場表達式\"中的值提示找不到地址,怎么解決?

    Cubeide1.18.1在線調試時,在\"現(xiàn)場表達式\"中添加全局變量,然后改變其數(shù)值,Console窗口提示: Failed to read all registers
    發(fā)表于 06-06 08:27

    Cubeide1.18.1在線調試改變\"現(xiàn)場表達式\"中的值提示找不到地址怎么解決?

    Cubeide1.18.1在線調試時,在\"現(xiàn)場表達式\"中添加全局變量,然后改變其數(shù)值,Console窗口提示: Failed to read all registers
    發(fā)表于 04-27 06:18

    Linux中文本處理命令的用法

    Linux 三劍客是(grep,sed,awk)三者的簡稱,熟練使用這三個工具可以提升運維效率。Linux 三劍客以正則表達式作為基礎,而在Linux系統(tǒng)中,支持兩種正則表達式,分別為“標準正則表達式”和“擴展
    的頭像 發(fā)表于 04-15 10:22 ?773次閱讀
    Linux中文本處理命令的用法

    HarmonyOS NEXT 原生應用/元服務-ArkTS代碼調試Evaluate and log

    開發(fā)者可以通過 Evaluate and log 能力在代碼執(zhí)行到斷點行時打印開發(fā)者指定的表達式。 操作步驟 在需要打印表達式結果的地方設置斷點。 右鍵斷點,然后點擊More按鈕。 勾選
    發(fā)表于 03-14 16:49