1. 程式人生 > >Python的__future__模組

Python的__future__模組

轉自:https://www.cnblogs.com/linyihan/p/5644262.html

Python的每個新版本都會增加一些新的功能,或者對原來的功能作一些改動。有些改動是不相容舊版本的,也就是在當前版本執行正常的程式碼,到下一個版本執行就可能不正常了。

從Python 2.7到Python 3.x就有不相容的一些改動,比如2.x裡的字串用'xxx'表示str,Unicode字串用u'xxx'表示unicode,而在3.x中,所有字串都被視為unicode,因此,寫u'xxx'和'xxx'是完全一致的,而在2.x中以'xxx'表示的str就必須寫成b'xxx',以此表示“二進位制字串”。

要直接把程式碼升級到3.x是比較冒進的,因為有大量的改動需要測試。相反,可以在2.7版本中先在一部分程式碼中測試一些3.x的特性,如果沒有問題,再移植到3.x不遲。

Python提供了__future__模組,把下一個新版本的特性匯入到當前版本,於是我們就可以在當前版本中測試一些新版本的特性。舉例說明如下:

為了適應Python 3.x的新的字串的表示方法,在2.7版本的程式碼中,可以通過unicode_literals來使用Python 3.x的新的語法:

# still running on Python 2.7

from __future__ import unicode_literals

print '\'xxx\' is unicode?', isinstance('xxx', unicode)
print 'u\'xxx\' is unicode?', isinstance(u'xxx', unicode)
print '\'xxx\' is str?', isinstance('xxx', str)
print 'b\'xxx\' is str?', isinstance(b'xxx', str)

注意到上面的程式碼仍然在Python 2.7下執行,但結果顯示去掉字首u的'a string'仍是一個unicode,而加上字首b的b'a string'才變成了str:

$ python task.py
'xxx' is unicode? True
u'xxx' is unicode? True
'xxx' is str? False
b'xxx' is str? True

類似的情況還有除法運算。在Python 2.x中,對於除法有兩種情況,如果是整數相除,結果仍是整數,餘數會被扔掉。

========================================================================================

轉自:https://blog.csdn.net/wonengguwozai/article/details/75267858

2. Python 2.7可以通過 import __future__ 來將2.7版本的print語句移除,讓你可以Python3.x的print()功能函式的形式。例如:

from __future__ import print_function  
print('hello', end='\t') 
 

3. 整數除法

python 2.7中:>>>23/6  >>>3  
from __future__ import division 之後:  
>>>23/6   >>> 3.8333333333333335 
 

4. with特性

from __future__ import with_statement

with open('test.txt', 'r') as f:
    for line in f:
        print line

with方式語句可以替換以前try..catch語句, 如果使用try..catch語句則為:
try:
    f = open('test.txt', 'r')
    for line in f:
        print line
finally:
    f.close()
而with程式碼塊如果內部出現任何錯誤, 都將會自動呼叫close方法