Head First Python 学习笔记-Chapter3:文件读取和异常处理
2017-07-22 10:32
525 查看
第三章中主要介绍了简单的文件读取和简单的异常处理操作。
首先建立文件文件夹:
1. 提前考虑好程序中可能出现的异常,对这些情况进行处理,从而避免异常的发生。
2. 採用异常捕获机制:让异常发生,可是对异常进行捕获。捕获到后再进行相关的操作。
2、
3、
4、
5、
6、
首先建立文件文件夹:
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
相关文章推荐
- Head First Python 学习笔记-Chapter3:文件读取和异常处理
- Head First Python 学习笔记-Chapter4:持久化--将数据写入文件
- Head First Python学习笔记2——文件与异常
- 【head First python】之文件与异常处理
- Head First Python (中文)学习笔记-第6章
- Python学习笔记(1~26页)(《Head First Python》)
- Head First Python (中文)学习笔记-第4章
- 【Head First Python-第六章-定制数据对象】学习笔记
- python核心编程学习笔记-2016-08-02-01-读取文件的函数中的文件指针问题
- Head_First_Python学习笔记(四)
- 《Head First Python》笔记 第三章 文件与异常
- Head First Python(如何向PYPI发布你的代码)学习笔记
- Head First Python (中文)学习笔记-1,2章
- Head First C学习笔记 chapter3 由库代劳 命令行选项
- Head First Python 学习笔记-Chapter5:数据处理
- [Head First Python]4.读取文件datafile.txt, 去除两边空格, 存储到列表,从列表格式化(nester.py)后输出到文件man.out,other.out
- head first python chap 5 学习笔记
- HeadFirstPython 学习笔记(0)--list comprehension(列表推导)
- Head_First_Python学习笔记(三)
- Head_First_Python学习笔记(一)