第三章中主要介绍了简单的文件读取和简单的异常处理操作。
首先建立文件目录:HeadFirstPython\chapter3
,在Head First Pythong官方网站下载需要使用的文件:sketch.txt,并放入到之前建好的目录中。
相关语法
读取文件
the_file = open('sketch.txt) # 打开文件,获取到文件对象
# 对文件中的数据进行一些处理
the_file.close() # 关闭文件
异常捕获
import sys
try:
# 可能会出现异常的代码
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])
交互式环境下获取文件
在python交互环境中(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循环获得文件的每一行
>>> for eachline in data:
print(eachline,end="")
对数据进一步的处理:异常处理
再看一下文件中的数据,发现每一行都是用“:”进行分隔的,因此考虑在输出时进行优化。在对文件进行处理时,会出现相应的问题,比如文件中有些行是不含有“:”的,这时就会跑抛出ValueError
异常,当文件不存在或者读取失败时,则会抛出IOError
,等等。面对这些异常,有两种处理思路:
1. 提前考虑好程序中可能出现的异常,对这些情况进行处理,从而避免异常的发生。
2. 采用异常捕获机制:让异常发生,但是对异常进行捕获,捕获到后再进行相关的操作。
第一种思路:
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()
:对字符串进行分割,函数原型是str.split(sep=None, maxsplit=-1)
,它包含两个参数,第一个是使用分割符,第二个是最大分割次数。如:
>>> '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()
:用来读取文件,同时创建了一个迭代器,可以对文件进行按行读取
3、readline()
:读取文件的一行
4、seek()
:将迭代器重新指向文件的开始处(第一行)
5、close()
:关闭打开的文件
6、find()
:查找子串在字符串中的位置,不存在则返回-1