第三章中主要介紹了簡單的文件讀取和簡單的異常處理操作。
首先建立文件目錄:HeadFirstPython\chapter3
,在Head First Pythong官方網(wǎng)站下載需要使用的文件:sketch.txt,并放入到之前建好的目錄中。
相關語法
讀取文件
the_file = open('sketch.txt) # 打開文件,獲取到文件對象
# 對文件中的數(shù)據(jù)進行一些處理
the_file.close() # 關閉文件
異常捕獲
import sys
try:
# 可能會出現(xiàn)異常的代碼
f = open('myfile.txt')
s = f.readline()
i = int(s.strip())
# 對異常進行處理
# 類似于Java中的catch塊
except OSError as err: # 可以指定待捕獲的異常
print("OS error: {0}".format(err))
except ValueError:
pass # 不做任何操作,直接跳過
except:
print("Unexpected error:", sys.exc_info()[0])
交互式環(huán)境下獲取文件
在python交互環(huán)境中(pyhton idle)中,可以使用如下的一些命令進行一些文件操作:
>>> import os # 從標準庫導入os
>>> os.getcwd() # 獲取當前的工作目錄,類似于Linux下的pwd
'D:\\program\\Python34'
>>> os.chdir("D:\code\python\HeadFirstPython\chapter3") # 切換工作目錄
>>> os.getcwd()
'D:\\code\\python\\HeadFirstPython\\chapter3'
>>> data = open('sketch.txt') # 打開文件,獲取到文件對象,相當于一個迭代器iterator
>>> print(data.readline(),end="") # 讀取文件的一行,data.readline()
Man: Is this the right room for an argument?
>>> print(data.readline(),end="")
Other Man: I've told you once.
>>> data.seek(0) # 使data回到文件起始位置
0
# 使用for循環(huán)獲得文件的每一行
>>> for eachline in data:
print(eachline,end="")
對數(shù)據(jù)進一步的處理:異常處理
再看一下文件中的數(shù)據(jù),發(fā)現(xiàn)每一行都是用“:”進行分隔的,因此考慮在輸出時進行優(yōu)化。在對文件進行處理時,會出現(xiàn)相應的問題,比如文件中有些行是不含有“:”的,這時就會跑拋出ValueError
異常,當文件不存在或者讀取失敗時,則會拋出IOError
,等等。面對這些異常,有兩種處理思路:
- 提前考慮好程序中可能出現(xiàn)的異常,對這些情況進行處理,從而避免異常的發(fā)生。
- 采用異常捕獲機制:讓異常發(fā)生,但是對異常進行捕獲,捕獲到后再進行相關的操作。
第一種思路:
import os
if os.path.exists('sketch.txt'):
data = open('sketch.txt')
for each_line in data:
if each_line.find(':') != -1:
(role, line_spoken) = each_line.split(':', 1)
print(role, end='')
print(' said: ', end='')
print(line_spoken,end='')
data.close()
else:
print('文件不存在!')
第二種思路:捕獲異常:
try:
data = open('sketch2.txt')
for each_line in data:
# if each_line.find(':') != -1:
try:
(role, line_spoken) = each_line.split(':', 1)
print(role, end='')
print(' said: ', end='')
print(line_spoken,end='')
except:
pass # 不做任何操作,直接跳過
data.close()
except:
print('文件不存在')
相關知識點
1、split()
:對字符串進行分割,函數(shù)原型是str.split(sep=None, maxsplit=-1)
,它包含兩個參數(shù),第一個是使用分割符,第二個是最大分割次數(shù)。如:
>>> '1,2,3'.split(',')
['1', '2', '3']
>>> '1,2,3'.split(',', maxsplit=1)
['1', '2,3']
>>> '1,2,,3,'.split(',')
['1', '2', '', '3', '']
>>> '1 2 3'.split()
['1', '2', '3']
>>> '1 2 3'.split(maxsplit=1)
['1', '2 3']
>>> ' 1 2 3 '.split()
['1', '2', '3']
2、open()
:用來讀取文件,同時創(chuàng)建了一個迭代器,可以對文件進行按行讀取
3、readline()
:讀取文件的一行
4、seek()
:將迭代器重新指向文件的開始處(第一行)
5、close()
:關閉打開的文件
6、find()
:查找子串在字符串中的位置,不存在則返回-1
如果覺得有用,歡迎關注我的微信,有問題可以直接交流:

你的關注是對我最大的鼓勵!