可能比較 low 還是記錄一下:
str 和 repr的使用過程
好,以上全是廢話
>>> a = 1>>> a + ""---------------------------------------------------------------------------TypeErrorTraceback (most recent call last)<ipython-input-5-ebf3ab7f3a34> in <module>()----> 1 a + ""TypeError: unsupported operand type(s) for +: 'int' and 'str'>>> a = 1>>> repr(a) + ""
可以看到, 我們可以通過使用 str 和 repr 來轉換字符串
但是,str 只能提供一個 元string來做轉換, 不可以是一個變量(她不具備執(zhí)行變量的能力)
repr 是一個函數(shù), 所以實際上是傳參, 可以是變量和string
好多人都知道str()能把123數(shù)字轉成字符串,python里的str()甚至還能把列表、字典等對象轉成字符串。這都好理解,可是一旦把str()和repr()放在一起,大家就全都不淡定了-_-!
來看一段代碼,仍是在IDLE里交互:
>>> str('hello') 'hello' >>> repr('hello') "'hello'" >>> str('你好') '\xc4\xe3\xba\xc3' >>> repr('你好') "'\\xc4\\xe3\\xba\\xc3'"
先看前兩句:英文的'hello'在str()后仍是'hello',可是在repr()后就變成了"'hello'"。這就說明,str()返回的就是字符串本身,而repr()雖然返回的也是字符串,但它是一個標準字符串,官方解釋比較繞,我來解釋下吧。repr是representation及描述的意思,不是對人的描述,而是對python機器的描述,也就是它會將某物返回一個它在python中的描述。說人話:repr(obj)告訴我們obj這個變量在背地里是什么樣子,在背地里是怎么被python處理被python"玩弄"的。
在python里,我們總會被眼睛欺騙。編輯器里顯示的東西,并不總是它原本的面貌。python為了方便,總是表面上一套,背地里又一套。
再來理解后兩句:中文的'你好'在str()后變成了編碼'\xc4\xe3\xba\xc3'
,在repr()后變成了"'\xc4\xe3\xba\xc3
'"。`都加上了轉移符變成\,相當于把字符串中的內容都“標準化”了。至于'變成"`只是為了說明repr()返回的是一個經過處理的新字符串。
print后的str()和repr()
來看代碼:
>>> print str('你好') 你好 >>> print repr('你好') '\xc4\xe3\xba\xc3'
之前str('你好')顯示的是'\xc4\xe3\xba\xc3',而一經過print,就變成了正確的'你好'。上面說過了,命令行里直接輸入一個變量,顯示的是它在python后臺存儲的數(shù)據(jù);而用print出來的東西,會顯出出盡量友好、讓人能看懂的東西。
理解了這個,對print這兩個結果的不同,也就全然理解了。然后也就放棄print作為考據(jù)的心了。