字符集是由一對方括號 “[]” 括起來的字符集合。使用字符集,可以匹配多個字符中的一個。
舉個例子,比如你使用 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
+關注
關注
57文章
4876瀏覽量
90025 -
正則表達式
+關注
關注
0文章
28瀏覽量
3850
發布評論請先 登錄
相關推薦
熱點推薦
布爾表達式及范圍檢查
一個常用的布爾表達式是用于判斷變量是否位于某個范圍內,
例如,檢查一個圖形坐標是否位于一個窗口內:
bool PointInRectangelArea (Point p, Rectangle
發表于 12-12 07:08
第4章 C語言基礎以及流水燈的實現(4.5 4.6)
(表達式) ? ? ? ?{ ? ? ? ? ? ?循環體語句; ? ? ? ?} 在C語言里,通常“表達式”符合條件叫做真,不符合條件,叫做假。比如前邊i while(表達式)這個括號里的
inline ASM(內聯匯編)的細節分享
內聯匯編,否則,仍然是帶有C++表達式的內聯江編,此時\"instructionlist\"中的寄存器的寫法需要遵守相關的規定: 寄存器前必須使用兩個百分號(%%),而不是像
發表于 10-31 09:11
如何給rt-thread studio 2.2.8 ide工具安裝支持其他字符編碼,如gb2312等?
目前使用的rt-thread studio版本為2.2.8,當前支持的字符集編碼如下
由于移植的工程,之前的文件編碼格式為gb2312的,因此在此ide中中文顯示為亂碼
請教如何給ide添加新的字符集支持。
發表于 09-29 07:41
labview如何使用VISA串口資源查找的正則表達式提取串口的資源名稱?
如圖,如何利用VISA資源查找的正則表達式從很多串口當中提取想要的目標串口(Quectel USB AT Port這個串口)?
發表于 07-07 17:20
基礎篇3:掌握Python中的條件語句與循環
不同的條件執行不同的代碼塊。Python中的條件語句主要使用if、elif(else if的縮寫)和else關鍵字。
if語句
最簡單的條件語句是if語句,它的工作方式如下:
復制代碼
if 條件表達式
發表于 07-03 16:13
Cubeide1.18.1在線調試改變\"現場表達式\"中的值提示找不到地址,為什么?
Cubeide1.18.1在線調試時,在\"現場表達式\"中添加全局變量,然后改變其數值,Console窗口提示:
Failed to read all registers
發表于 06-12 06:50
《ESP32S3 Arduino開發指南》第三章 C/C++語言基礎
基礎,由于篇幅有限,在此僅對C/C++語言基礎進行簡單介紹。本章將分為如下9個小節:3.1 數據類型3.2 運算符3.3 表達式3.4 數組3.5 字符串3.6 注釋3.7 順序結構3.8 選擇結構
發表于 06-10 09:20
Cubeide1.18.1在線調試改變\"現場表達式\"中的值提示找不到地址是怎么回事?
Cubeide1.18.1在線調試時,在\"現場表達式\"中添加全局變量,然后改變其數值,Console窗口提示:
Failed to read all registers
發表于 06-10 08:26
干貨分享 | 零基礎上手!TSMaster圖形信號表達式實操指南
TSMaster軟件支持在圖形里面的信號表達式功能,主要用于多信號表達式運算和顯示的場景。本文將以A2L中的標定變量為例,介紹如何使用圖形中的信號表達式功能進行多信號的后處理運算和顯示。本文關鍵詞
Cubeide1.18.1在線調試改變\"現場表達式\"中的值提示找不到地址,怎么解決?
Cubeide1.18.1在線調試時,在\"現場表達式\"中添加全局變量,然后改變其數值,Console窗口提示:
Failed to read all registers
發表于 06-06 08:27
Cubeide1.18.1在線調試改變\"現場表達式\"中的值提示找不到地址怎么解決?
Cubeide1.18.1在線調試時,在\"現場表達式\"中添加全局變量,然后改變其數值,Console窗口提示:
Failed to read all registers
發表于 04-27 06:18
Linux中文本處理命令的用法
Linux 三劍客是(grep,sed,awk)三者的簡稱,熟練使用這三個工具可以提升運維效率。Linux 三劍客以正則表達式作為基礎,而在Linux系統中,支持兩種正則表達式,分別為“標準正則表達式”和“擴展
HarmonyOS NEXT 原生應用/元服務-ArkTS代碼調試Evaluate and log
開發者可以通過 Evaluate and log 能力在代碼執行到斷點行時打印開發者指定的表達式。
操作步驟
在需要打印表達式結果的地方設置斷點。
右鍵斷點,然后點擊More按鈕。
勾選
發表于 03-14 16:49
python正則表達式字符集
評論