在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

python正則表達式字符集

python爬蟲知識分享 ? 來源:python爬蟲知識分享 ? 作者:python爬蟲知識分享 ? 2022-03-17 16:48 ? 次閱讀

字符集是由一對方括號 “[]” 括起來的字符集合。使用字符集,可以匹配多個字符中的一個。

舉個例子,比如你使用 C[ET]O 匹配到的是 CEO 或 CTO ,也就是說 [ET] 代表的是一個 E 或者一個 T 。像上面提到的 [a-z] ,就是所有小寫字母中的其中一個,這里使用了連字符 “-” 定義一個連續字符的字符范圍。當然,像這種寫法,里面可以包含多個字符范圍的,比如:[0-9a-fA-F] ,匹配單個的十六進制數字,且不分大小寫。注意了,字符和范圍定義的先后順序對匹配的結果是沒有任何影響的。

其實說了那么多,只是想證明,字符集一對方括號 “[]” 里面的字符關系是"或(OR)"關系,下面看一個例子:

import re
a = 'uav,ubv,ucv,uwv,uzv,ucv,uov'

# 字符集

# 取 u 和 v 中間是 a 或 b 或 c 的字符
findall = re.findall('u[abc]v', a)
print(findall)
# 如果是連續的字母,數字可以使用 - 來代替
l = re.findall('u[a-c]v', a)
print(l)

# 取 u 和 v 中間不是 a 或 b 或 c 的字符
re_findall = re.findall('u[^abc]v', a)
print(re_findall)

輸出的結果:

['uav', 'ubv', 'ucv', 'ucv']
['uav', 'ubv', 'ucv', 'ucv']
['uwv', 'uzv', 'uov']

在例子中,使用了取反字符集,也就是在左方括號 “[” 后面緊跟一個尖括號 “^”,就會對字符集取反。需要記住的一點是,取反字符集必須要匹配一個字符。比如:q[^u] 并不意味著:匹配一個 q,后面沒有 u 跟著。它意味著:匹配一個 q,后面跟著一個不是 u 的字符。具體可以對比上面例子中輸出的結果來理解。

我們都知道,正則表達式本身就定義了一些規則,比如 \d,匹配所有數字字符,其實它是等價于 [0-9],下面也寫了個例子,通過字符集的形式解釋了這些特殊字符。

import re

a = 'uav_ubv_ucv_uwv_uzv_ucv_uov&123-456-789'

# 概括字符集

# \d 相當于 [0-9] ,匹配所有數字字符
# \D 相當于 [^0-9] , 匹配所有非數字字符
findall1 = re.findall('\d', a)
findall2 = re.findall('[0-9]', a)
findall3 = re.findall('\D', a)
findall4 = re.findall('[^0-9]', a)
print(findall1)
print(findall2)
print(findall3)
print(findall4)

# \w 匹配包括下劃線的任何單詞字符,等價于 [A-Za-z0-9_]
findall5 = re.findall('\w', a)
findall6 = re.findall('[A-Za-z0-9_]', a)
print(findall5)
print(findall6)

輸出結果:

['1', '2', '3', '4', '5', '6', '7', '8', '9']
['1', '2', '3', '4', '5', '6', '7', '8', '9']
['u', 'a', 'v', '_', 'u', 'b', 'v', '_', 'u', 'c', 'v', '_', 'u', 'w', 'v', '_', 'u', 'z', 'v', '_', 'u', 'c', 'v', '_', 'u', 'o', 'v', '&', '-', '-']
['u', 'a', 'v', '_', 'u', 'b', 'v', '_', 'u', 'c', 'v', '_', 'u', 'w', 'v', '_', 'u', 'z', 'v', '_', 'u', 'c', 'v', '_', 'u', 'o', 'v', '&', '-', '-']
['u', 'a', 'v', '_', 'u', 'b', 'v', '_', 'u', 'c', 'v', '_', 'u', 'w', 'v', '_', 'u', 'z', 'v', '_', 'u', 'c', 'v', '_', 'u', 'o', 'v', '1', '2', '3', '4', '5', '6', '7', '8', '9']
['u', 'a', 'v', '_', 'u', 'b', 'v', '_', 'u', 'c', 'v', '_', 'u', 'w', 'v', '_', 'u', 'z', 'v', '_', 

審核編輯:符乾江
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • python
    +關注

    關注

    56

    文章

    4804

    瀏覽量

    84912
  • 正則表達式
    +關注

    關注

    0

    文章

    27

    瀏覽量

    3531
收藏 人收藏

    評論

    相關推薦

    Linux grep命令詳解

    Linux grep命令是一種非常常用的文本搜索工具,它可以在給定的文件中搜索匹配的字符串,并輸出匹配的行。grep是全稱“global search regular expression print”,可以識別正則表達式,并使用正則表
    的頭像 發表于 12-25 09:39 ?207次閱讀

    詳解nginx中的正則表達式

    前言,我這里驗證的nginx-v1.23.2單機環境下的nginx中的正則表達式、location路徑匹配規則和優先級。
    的頭像 發表于 12-03 09:59 ?307次閱讀
    詳解nginx中的<b class='flag-5'>正則表達式</b>

    4G模組LuatOS開發|iconv字符集轉換技術篇

    本次我要講的是4G模組LuatOS開發的iconv字符集轉換,已整理成文,今天便分享供大家。
    的頭像 發表于 11-30 09:53 ?247次閱讀
    4G模組LuatOS開發|iconv<b class='flag-5'>字符集</b>轉換技術篇

    Verilog表達式的位寬確定規則

    很多時候,Verilog中表達式的位寬都是被隱式確定的,即使你自己設計了位寬,它也是根據規則先確定位寬后,再擴展到你的設計位寬,這常常會導致結果產生意想不到的錯誤。
    的頭像 發表于 10-22 15:41 ?582次閱讀
    Verilog<b class='flag-5'>表達式</b>的位寬確定規則

    通過工業智能網關實現中間變量表達式的快速配置

    ,出現告警可能是多個變量達到條件而觸發的,就需要對中間變量進行配置。 對此,物通博聯提供基于工業智能網關實現中間變量表達式的快速配置操作。用戶可以根據生產現場的應用需求,靈活配置中間變量表達式,實現多參數、多條件
    的頭像 發表于 10-08 17:10 ?285次閱讀
    通過工業智能網關實現中間變量<b class='flag-5'>表達式</b>的快速配置

    nginx中的正則表達式和location路徑匹配指南

    前言,我這里驗證的nginx-v1.23.2單機環境下的nginx中的正則表達式、location路徑匹配規則和優先級。
    的頭像 發表于 09-29 16:02 ?894次閱讀
    nginx中的<b class='flag-5'>正則表達式</b>和location路徑匹配指南

    求助,以下恒流源電路Io的計算表達式怎么計算?

    這個恒流源電路Io的計算表達式怎么計算,求給出詳細計算過程
    發表于 08-22 08:16

    TestStand表達式中常用的語法規則和運算符使用

    TestStand也有自己的語言嘛?在回答這個問題之前大家可以想一下在使用TestStand時有一個和語言密切相關的屬性。沒錯那就是表達式(Expressions),在這篇文章中,小編將以Q&A的方式來帶著大家來理解并熟悉TestStand表達式中較為常用的一些語法規則以
    的頭像 發表于 08-15 18:10 ?1679次閱讀
    TestStand<b class='flag-5'>表達式</b>中常用的語法規則和運算符使用

    Java表達式引擎選型調研分析

    1 簡介 我們項目組主要負責面向企業客戶的業務系統, 企業的需求往往是多樣化且復雜的,對接不同企業時會有不同的定制化的業務模型和流程。 我們在業務系統中 使用表達式引擎,集中配置管理業務規則,并實現
    的頭像 發表于 08-15 14:25 ?395次閱讀
    Java<b class='flag-5'>表達式</b>引擎選型調研分析

    鴻蒙原生應用元服務開發-倉頡基本概念表達式(二)

    ,繼續執行 for-in 表達式后面的代碼。 說明 倉頡內置的區間和數組等類型已經擴展了 Iterable 接口。 例如,以下程序使用 for-in 表達式,遍歷中國地支字符構成的數組
    發表于 08-09 14:26

    鴻蒙原生應用元服務開發-倉頡基本概念表達式(一)

    在一些傳統編程語言中,一個表達式由一個或多個操作數(operand)通過零個或多個操作符(operator)組合而成,表達式總是隱含著一個計算過程,因此每個表達式都會有一個計算結果,對于只有操作數而
    發表于 08-08 10:27

    求助,有關表達式選項卡(ADS)的問題求解

    你好。 我看不到表達式選項卡中的某些變量值。 數組的大小顯然是 256,但我最多只能看到 100。 請問問題出在哪里? 謝謝。
    發表于 06-03 06:23

    BGP路由過濾、引入與缺省路由的配置實踐

    第一個用 AS-Path進行路由過濾 利用 AS-Path 進行路由過濾 讓R3只接收來自AS 100的 做正則表達式
    發表于 04-08 10:47 ?1484次閱讀
    BGP路由過濾、引入與缺省路由的配置實踐

    mapgis屬性篩選表達式

    篇文章中,我們將詳細討論MapGIS的屬性篩選表達式,包括語法、操作符和函數等。 屬性篩選表達式是一種在MapGIS中用于指定要素選擇條件的代碼。它由一組操作符、函數和屬性字段組成,用于描述要篩選的要素的特征。在MapGIS中,屬性篩選
    的頭像 發表于 02-25 10:58 ?1725次閱讀

    西門子博途的算術表達式

    算術表達式既可以是一個數字值,也可以是由帶有算術運算符的兩個值或表達式組合而成。 算術運算符可以處理當前 CPU 所支持的各種數據類型。如果在該運算中有 2 個操作數,那么可根據以下條件來確定結果的數據類型。
    的頭像 發表于 01-24 11:36 ?1058次閱讀
    主站蜘蛛池模板: 国产一二精品| 97人人模人人揉人人捏| 日韩毛片网站| 欧美成人午夜视频| 美国色综合| 国产免费色视频| 爆操极品美女| 午夜神马| 国产午夜一区二区在线观看| 中国高清性色生活片| 在线观看免费视频一区| 久久精品免费在线观看| 亚洲国产色图| 色停停| 美女视频一区| 4虎影院永久地址www| 手机在线你懂得| v视界影院最新地址| 亚洲精品国产自在久久出水| 一区精品视频| 日韩免费高清一级毛片在线| 久久人人做人人玩人精品| www.四虎影| 深夜久久| 黄色欧美| 亚洲成人资源| 国模私拍一区二区三区| 色片免费网站| 国产黄色小视频在线观看| kkkbo色综合| 日本黄色免费电影| 国产乱码免费卡1卡二卡3卡四 | 欧美成人午夜不卡在线视频| 国产精品激情综合久久| 手机精品视频在线观看免费| 午夜视频免费观看黄| 最新天堂| 欧美视频亚洲色图| 77se77亚洲欧美在线大屁股| 黄色靠逼网站| 高h细节肉爽文bl文|