《Head First Python》筆記 第四章 持久存儲

感受比Java簡單許多啊...函數

持久存儲 Persistent:Saving data to file

將基於內存的數據存儲到磁盤上測試

對於文件的處理,通常是打開文件,獲取文件內容,進行處理。處理結果能夠在屏幕上顯示,也能夠保存在其餘文件中。好比上一章對話的例子,將不一樣人說的話顯示,或者保存在文件中。ui

在此輸入圖片描述

Python中的字符串是不可變的(數值類型也不可變),strip()方法會建立一個新的字符串,將結果返回給line_spokenthis

Python變量只包含數據對象的一個引用,數據對象才真正包含數據(聯想:變量無類型)rest

Open your file in write mode(寫模式)

使用open() BIF打開磁盤文件時,能夠指定使用什麼訪問模式,默認r模式(讀)。code

寫模式即w模式。orm

在此輸入圖片描述

默認地,print() BIF顯示數據時會使用標準輸出(一般是屏幕)。要把數據寫至一個文件,須要使用file參數來指定所使用的數據文件對象(默認file=sys.stdout):對象

在此輸入圖片描述

寫入完成後,必定要關閉文件,確保全部數據都寫至磁盤。這稱爲刷新輸出(flushing),這一點很是重要。圖片

out.close() # 後面會講到使用with關鍵字幫助處理這個過程

在此輸入圖片描述

在文件處理過程當中,若是出現錯誤,則打開的文件將不會關閉,可使用finally進行關閉。ip

在此輸入圖片描述

When an error occurs at runtime, Python raises an exception of the specific type (such as IOError, ValueError , and so on). Additionally, Python creates an exception object that is passed as an argument to your except suite.

with處理文件

下圖兩種方法實現同樣的功能

在此輸入圖片描述

知識點

  1. 當文件不存在時,數據文件對象並未建立,即data不存在,調用close()方法會有異常,locals() BIF會返回當前做用域中的變量集合,使用if 'data' in locals() :進行測試。
  2. Python解釋器將一個異常對象傳入except組,as關鍵字能夠將異常對象賦值至一個標識符,但不能直接打印,應該使用str() BIF把異常對象轉換爲字符串。
  3. The str() BIF can be used to access the stringed representation of any data object that supports the conversion.

因爲處理文件時try/except/finally模式至關經常使用,因此Python提供了一個語句來抽象出相關的一些細節。The with statement, when used with files, can dramatically reduce the amount of code you have to write, because it negates the need to include a finally suite to handle the closing of a potentially opened data file.

with語句會自動處理全部已打開文件的關閉工做,即便出現異常也不例外。with語句也使用as關鍵字。

在此輸入圖片描述

The with statement takes advantage of a Python technology called the context management protocol(上下文管理協議).

print() BIF:

在此輸入圖片描述

Pickle your data

Python ships with a standard library called pickle, which can save and load almost any Python data object, including lists.至關因而Java對象的序列化。以下圖:

在此輸入圖片描述

You can, for example, store your pickled data on disk, put it in a database, or transfer it over a network to another computer.

When you are ready, reversing this process unpickles your persistent pickled data and recreates your data in its original form within Python's memory:

在此輸入圖片描述

標準庫存的pickle模塊容許你容易而高效地將Python數據對象保存到磁盤以及從磁盤恢復。

dump保存,用load恢復

Using pickle is straightforward: import the required module, then use dump() to save your data and, some time later, load() to restore it. The only requirement when working with pickled files is that they have to be opened in binary access mode:

在此輸入圖片描述

dump()load()方法都會拋出pickle.PickleError,所以須要進行捕獲。

在此輸入圖片描述

這樣保存list的方式,能夠不使用print(list, fiie='man.txt')的方式,而使用pickle.dump(list, 'man.txt')的方式。

本章還改進了nester.py,爲print_lol()函數加入了fh=sys.stdout可選參數。可與load()結合使用打印列表。

相關文章
相關標籤/搜索