python中 r、b、u、f 的含義

r/R:非轉義的原始字符串

與普通字符相比,其他相對特殊的字符,其中可能包含轉義字符。即,反斜槓加上對應字母,表示對應的特殊含義的,比如最常見的”\n”表示換行,”\t”表示Tab等。而如果是以r開頭,那麼說明後面的字符,都是普通的字符了,即如果是”\n”那麼表示一個反斜槓字符,一個字母n,而不是表示換行了。

以r開頭的字符,常用於正則表達式,對應着re模塊。

r'input\n' # 非轉義原生字符,經處理”\n”變成了”\”和”n”。也就是\n表示的是兩個字符,而不是換行。

輸出:

'input\\n'

b:bytes

python3.x裏默認的str是(py2.x裏的)unicode, bytes是(py2.x)的str, b''前綴代表的就是bytes

python2.x裏, b前綴沒什麼具體意義, 只是爲了兼容python3.x的這種寫法

b'input\n' # bytes字節符,打印以b開頭。

輸出:

b'input\n'

u/U:表示unicode字符串

不是僅僅是針對中文, 可以針對任何的字符串,代表是對字符串進行unicode編碼。

一般英文字符在使用各種編碼下, 基本都可以正常解析, 所以一般不帶u;但是中文, 必須表明所需編碼, 否則一旦編碼轉換就會出現亂碼。

注:建議所有編碼方式採用utf8

u'input\n' # unicode編碼字符,python3默認字符串編碼方式。

輸出:

'input\n'

f/format():格式化操作

案例如下:

name = "apollo"

print("My name is %s" % name)
print("My name is {}".format(name))

輸出:

My name is apollo
My name is apollo
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章