Python原始字符串(raw strings)用法實例
本文實例講述了Python原始字符串(raw strings)用法,分享給大家供大家參考。具體如下:
Python原始字符串的產(chǎn)生正是由于有正則表達式的存在。原因是ASCII 字符和正則表達式特殊字符間所產(chǎn)生的沖突。比如,特殊符號“\b”在ASCII 字符中代表退格鍵,但同時“\b”也是一個正則表達式的特殊符號,代表“匹配一個單詞邊界”。
為了讓RE 編譯器把兩個字符“\b”當成你想要表達的字符串,而不是一個退格鍵,你需要用另一個反斜線對它進行轉(zhuǎn)義,即可以這樣寫:“\\b”。
但這樣做會把問題復雜化,特別是當你的正則表達式字符串里有很多特殊字符時,就更容易令人困惑了。一般來說,原始字符串經(jīng)常被用于簡化正則表達式的復雜程度。
事實上,很多Python 程序員在定義正則表達式時都只使用原始字符串。
下面的例子用來說明退格鍵“\b” 和正則表達式“\b”(包含或不包含原始字符串)之間的區(qū)別:
...
>>> m = re.match('\\bblow', 'blow') # escaped \, now it works #用\轉(zhuǎn)義后,現(xiàn)在匹配了
>>> if m is not None: m.group()
...
'blow'
>>> m = re.match(r'\bblow', 'blow') # use raw string instead #改用原始字符串>>> if m is not None: m.group()
...
'blow'
你可能注意到我們在正則表達式里使用“\d”,沒用原始字符串,也沒出現(xiàn)什么問題。那是因為ASCII 里沒有對應的特殊字符,所以正則表達式編譯器能夠知道你指的是一個十進制數(shù)字。
原始字符串的這個特性讓一些工作變得非常的方便,比如正則表達式的創(chuàng)建。正則表達式是一些定義了高級搜索匹配方式的字符串,通常是由代表字符、分組、匹配信息、變量名和字符類等的特殊符號組成。正則表達式模塊已經(jīng)包含了足夠用的符號。但當你必須插入額外的符號來使特殊字符表現(xiàn)的像普通字符的時候,你就陷入了“字符數(shù)字”的泥潭!這時原始字符串就會派上用場了。
除了原始字符串符號(引號前面的字母“r”)以外,原始字符串跟普通字符串有著幾乎完全相同的語法。這個'r'可以是小寫也可以是大寫,唯一的要求是必須緊靠在第一個引號前。在3個例子的第1個例子里面,我們需要一個反斜杠加一個“n”來而不是一個換行符。
'\n'
>>> print '\n'
>>> r'\n'
'\\n'
>>> print r'\n'
\n
接下來的例子里,我們打不開我們的README文件了,為什么?因為'\t'和'\r'被當成不在我們的文件名中的特殊符號,但它們實際上是文件路徑中的4個獨立的字符。
File "", line 1, in ?
f = open('C:\windows\temp\readme.txt', 'r')IOError: [Errno 2] No such file or directory: 'C:\\win- dows\\temp\readme.txt'
>>> f = open(r'C:\windows\temp\readme.txt', 'r')>>> f.readline()
'Table of Contents (please check timestamps for last update!)\n'
>>> f.close()
希望本文所述對大家的Python程序設計有所幫助。
- python實現(xiàn)字典(dict)和字符串(string)的相互轉(zhuǎn)換方法
- Python 字符串操作(string替換、刪除、截取、復制、連接、比較、查找、包含、大小寫轉(zhuǎn)換、分割等)
- 詳解python 字符串和日期之間轉(zhuǎn)換 StringAndDate
- Python列表(list)、字典(dict)、字符串(string)基本操作小結(jié)
- Python的string模塊中的Template類字符串模板用法
- python開發(fā)之字符串string操作方法實例詳解
- Python實現(xiàn)string字符串連接的方法總結(jié)【8種方式】
- Python 基礎之字符串string詳解及實例
- python字符串string的內(nèi)置方法實例詳解
- Python數(shù)據(jù)類型之String字符串實例詳解
相關(guān)文章
python數(shù)據(jù)分析基礎之pandas中l(wèi)oc()與iloc()的介紹與區(qū)別介紹
我們經(jīng)常在尋找數(shù)據(jù)的某行或者某列的時常用到Pandas中的兩種方法iloc和loc,兩種方法都接收兩個參數(shù),第一個參數(shù)是行的范圍,第二個參數(shù)是列的范圍,這篇文章主要介紹了python數(shù)據(jù)分析基礎之pandas中l(wèi)oc()與iloc()的介紹與區(qū)別,需要的朋友可以參考下2024-07-07
Python中調(diào)用和運行其他.py文件的多種實現(xiàn)方法
本文介紹了在Python中調(diào)用和運行其他.py文件的四種方法:subprocess模塊、exec函數(shù)、import語句和os.system函數(shù),每種方法都有其適用場景和優(yōu)缺點2025-02-02

