Python 3 教程
在前面幾個(gè)章節(jié)中,我們其實(shí)已經(jīng)接觸了 Python 的輸入輸出的功能。本章節(jié)我們將具體介紹 Python 的輸入輸出。
Python兩種輸出值的方式: 表達(dá)式語(yǔ)句和 print() 函數(shù)。
第三種方式是使用文件對(duì)象的 write() 方法,標(biāo)準(zhǔn)輸出文件可以用 sys.stdout 引用。
如果你希望輸出的形式更加多樣,可以使用 str.format() 函數(shù)來(lái)格式化輸出值。
如果你希望將輸出的值轉(zhuǎn)成字符串,可以使用 repr() 或 str() 函數(shù)來(lái)實(shí)現(xiàn)。
這里有兩種方式輸出一個(gè)平方與立方的表:
注意:在第一個(gè)例子中, 每列間的空格由 print() 添加。
這個(gè)例子展示了字符串對(duì)象的 rjust() 方法, 它可以將字符串靠右, 并在左邊填充空格。
還有類(lèi)似的方法, 如 ljust() 和 center()。 這些方法并不會(huì)寫(xiě)任何東西, 它們僅僅返回新的字符串。
另一個(gè)方法 zfill(), 它會(huì)在數(shù)字的左邊填充 0,如下所示:
str.format() 的基本使用如下:
括號(hào)及其里面的字符 (稱(chēng)作格式化字段) 將會(huì)被 format() 中的參數(shù)替換。
在括號(hào)中的數(shù)字用于指向傳入對(duì)象在 format() 中的位置,如下所示:
如果在 format() 中使用了關(guān)鍵字參數(shù), 那么它們的值會(huì)指向使用該名字的參數(shù)。
位置及關(guān)鍵字參數(shù)可以任意的結(jié)合:
!a (使用 ascii()), !s (使用 str()) 和 !r (使用 repr()) 可以用于在格式化某個(gè)值之前對(duì)其進(jìn)行轉(zhuǎn)化:
可選項(xiàng) : 和格式標(biāo)識(shí)符可以跟著字段名。 這就允許對(duì)值進(jìn)行更好的格式化。 下面的例子將 Pi 保留到小數(shù)點(diǎn)后三位:
在 : 后傳入一個(gè)整數(shù), 可以保證該域至少有這么多的寬度。 用于美化表格時(shí)很有用。
如果你有一個(gè)很長(zhǎng)的格式化字符串, 而你不想將它們分開(kāi), 那么在格式化時(shí)通過(guò)變量名而非位置會(huì)是很好的事情。
最簡(jiǎn)單的就是傳入一個(gè)字典, 然后使用方括號(hào) [] 來(lái)訪問(wèn)鍵值 :
也可以通過(guò)在 table 變量前使用 ** 來(lái)實(shí)現(xiàn)相同的功能:
% 操作符也可以實(shí)現(xiàn)字符串格式化。 它將左邊的參數(shù)作為類(lèi)似 sprintf() 式的格式化字符串, 而將右邊的代入, 然后返回格式化后的字符串. 例如:
因?yàn)?str.format() 是比較新的函數(shù), 大多數(shù)的 Python 代碼仍然使用 % 操作符。但是因?yàn)檫@種舊式的格式化最終會(huì)從該語(yǔ)言中移除, 應(yīng)該更多的使用 str.format().
Python提供了 input() 內(nèi)置函數(shù)從標(biāo)準(zhǔn)輸入讀入一行文本,默認(rèn)的標(biāo)準(zhǔn)輸入是鍵盤(pán)。
input 可以接收一個(gè)Python表達(dá)式作為輸入,并將運(yùn)算結(jié)果返回。
這會(huì)產(chǎn)生如下的對(duì)應(yīng)著輸入的結(jié)果:
請(qǐng)輸入:小白教程 你輸入的內(nèi)容是: 小白教程
open() 將會(huì)返回一個(gè) file 對(duì)象,基本語(yǔ)法格式如下:
open(filename, mode)
不同模式打開(kāi)文件的完全列表:
模式 | 描述 |
---|---|
r | 以只讀方式打開(kāi)文件。文件的指針將會(huì)放在文件的開(kāi)頭。這是默認(rèn)模式。 |
rb | 以二進(jìn)制格式打開(kāi)一個(gè)文件用于只讀。文件指針將會(huì)放在文件的開(kāi)頭。 |
r+ | 打開(kāi)一個(gè)文件用于讀寫(xiě)。文件指針將會(huì)放在文件的開(kāi)頭。 |
rb+ | 以二進(jìn)制格式打開(kāi)一個(gè)文件用于讀寫(xiě)。文件指針將會(huì)放在文件的開(kāi)頭。 |
w | 打開(kāi)一個(gè)文件只用于寫(xiě)入。如果該文件已存在則打開(kāi)文件,并從開(kāi)頭開(kāi)始編輯,即原有內(nèi)容會(huì)被刪除。如果該文件不存在,創(chuàng)建新文件。 |
wb | 以二進(jìn)制格式打開(kāi)一個(gè)文件只用于寫(xiě)入。如果該文件已存在則打開(kāi)文件,并從開(kāi)頭開(kāi)始編輯,即原有內(nèi)容會(huì)被刪除。如果該文件不存在,創(chuàng)建新文件。 |
w+ | 打開(kāi)一個(gè)文件用于讀寫(xiě)。如果該文件已存在則打開(kāi)文件,并從開(kāi)頭開(kāi)始編輯,即原有內(nèi)容會(huì)被刪除。如果該文件不存在,創(chuàng)建新文件。 |
wb+ | 以二進(jìn)制格式打開(kāi)一個(gè)文件用于讀寫(xiě)。如果該文件已存在則打開(kāi)文件,并從開(kāi)頭開(kāi)始編輯,即原有內(nèi)容會(huì)被刪除。如果該文件不存在,創(chuàng)建新文件。 |
a | 打開(kāi)一個(gè)文件用于追加。如果該文件已存在,文件指針將會(huì)放在文件的結(jié)尾。也就是說(shuō),新的內(nèi)容將會(huì)被寫(xiě)入到已有內(nèi)容之后。如果該文件不存在,創(chuàng)建新文件進(jìn)行寫(xiě)入。 |
ab | 以二進(jìn)制格式打開(kāi)一個(gè)文件用于追加。如果該文件已存在,文件指針將會(huì)放在文件的結(jié)尾。也就是說(shuō),新的內(nèi)容將會(huì)被寫(xiě)入到已有內(nèi)容之后。如果該文件不存在,創(chuàng)建新文件進(jìn)行寫(xiě)入。 |
a+ | 打開(kāi)一個(gè)文件用于讀寫(xiě)。如果該文件已存在,文件指針將會(huì)放在文件的結(jié)尾。文件打開(kāi)時(shí)會(huì)是追加模式。如果該文件不存在,創(chuàng)建新文件用于讀寫(xiě)。 |
ab+ | 以二進(jìn)制格式打開(kāi)一個(gè)文件用于追加。如果該文件已存在,文件指針將會(huì)放在文件的結(jié)尾。如果該文件不存在,創(chuàng)建新文件用于讀寫(xiě)。 |
下圖很好的總結(jié)了這幾種模式:
模式 | r | r+ | w | w+ | a | a+ |
---|---|---|---|---|---|---|
讀 | + | + | + | + | ||
寫(xiě) | + | + | + | + | + | |
創(chuàng)建 | + | + | + | + | ||
覆蓋 | + | + | ||||
指針在開(kāi)始 | + | + | + | + | ||
指針在結(jié)尾 | + | + |
以下實(shí)例將字符串寫(xiě)入到文件 foo.txt 中:
此時(shí)打開(kāi)文件 foo.txt,顯示如下:
$ cat /tmp/foo.txt Python 是一個(gè)非常好的語(yǔ)言。 是的,的確非常好!!
本節(jié)中剩下的例子假設(shè)已經(jīng)創(chuàng)建了一個(gè)稱(chēng)為 f 的文件對(duì)象。
為了讀取一個(gè)文件的內(nèi)容,調(diào)用 f.read(size), 這將讀取一定數(shù)目的數(shù)據(jù), 然后作為字符串或字節(jié)對(duì)象返回。
size 是一個(gè)可選的數(shù)字類(lèi)型的參數(shù)。 當(dāng) size 被忽略了或者為負(fù), 那么該文件的所有內(nèi)容都將被讀取并且返回。
以下實(shí)例假定文件 foo.txt 已存在(上面實(shí)例中已創(chuàng)建):
執(zhí)行以上程序,輸出結(jié)果為:
Python 是一個(gè)非常好的語(yǔ)言。 是的,的確非常好!!
f.readline() 會(huì)從文件中讀取單獨(dú)的一行。換行符為 'n'。f.readline() 如果返回一個(gè)空字符串, 說(shuō)明已經(jīng)已經(jīng)讀取到最后一行。
執(zhí)行以上程序,輸出結(jié)果為:
Python 是一個(gè)非常好的語(yǔ)言。
f.readlines() 將返回該文件中包含的所有行。
如果設(shè)置可選參數(shù) sizehint, 則讀取指定長(zhǎng)度的字節(jié), 并且將這些字節(jié)按行分割。
執(zhí)行以上程序,輸出結(jié)果為:
['Python 是一個(gè)非常好的語(yǔ)言。n', '是的,的確非常好!!n']
另一種方式是迭代一個(gè)文件對(duì)象然后讀取每行:
執(zhí)行以上程序,輸出結(jié)果為:
Python 是一個(gè)非常好的語(yǔ)言。 是的,的確非常好!!
這個(gè)方法很簡(jiǎn)單, 但是并沒(méi)有提供一個(gè)很好的控制。 因?yàn)閮烧叩奶幚頇C(jī)制不同, 最好不要混用。
f.write(string) 將 string 寫(xiě)入到文件中, 然后返回寫(xiě)入的字符數(shù)。
執(zhí)行以上程序,輸出結(jié)果為:
29
如果要寫(xiě)入一些不是字符串的東西, 那么將需要先進(jìn)行轉(zhuǎn)換:
執(zhí)行以上程序,打開(kāi) foo1.txt 文件:
$ cat /tmp/foo1.txt ('', 14)
f.tell() 返回文件對(duì)象當(dāng)前所處的位置, 它是從文件開(kāi)頭開(kāi)始算起的字節(jié)數(shù)。
如果要改變文件當(dāng)前的位置, 可以使用 f.seek(offset, from_what) 函數(shù)。
from_what 的值, 如果是 0 表示開(kāi)頭, 如果是 1 表示當(dāng)前位置, 2 表示文件的結(jié)尾,例如:
from_what 值為默認(rèn)為0,即文件開(kāi)頭。下面給出一個(gè)完整的例子:
在文本文件中 (那些打開(kāi)文件的模式下沒(méi)有 b 的), 只會(huì)相對(duì)于文件起始位置進(jìn)行定位。
當(dāng)你處理完一個(gè)文件后, 調(diào)用 f.close() 來(lái)關(guān)閉文件并釋放系統(tǒng)的資源,如果嘗試再調(diào)用該文件,則會(huì)拋出異常。
當(dāng)處理一個(gè)文件對(duì)象時(shí), 使用 with 關(guān)鍵字是非常好的方式。在結(jié)束后, 它會(huì)幫你正確的關(guān)閉文件。 而且寫(xiě)起來(lái)也比 try - finally 語(yǔ)句塊要簡(jiǎn)短:
文件對(duì)象還有其他方法, 如 isatty() 和 trucate(), 但這些通常比較少用。
python的pickle模塊實(shí)現(xiàn)了基本的數(shù)據(jù)序列和反序列化。
通過(guò)pickle模塊的序列化操作我們能夠?qū)⒊绦蛑羞\(yùn)行的對(duì)象信息保存到文件中去,永久存儲(chǔ)。
通過(guò)pickle模塊的反序列化操作,我們能夠從文件中創(chuàng)建上一次程序保存的對(duì)象。
基本接口:
pickle.dump(obj, file, [,protocol])
有了 pickle 這個(gè)對(duì)象, 就能對(duì) file 以讀取的形式打開(kāi):
x = pickle.load(file)
注解:從 file 中讀取一個(gè)字符串,并將它重構(gòu)為原來(lái)的python對(duì)象。
file: 類(lèi)文件對(duì)象,有read()和readline()接口。