Head First Python 学习笔记-Chapter3:文件读取和异常处理
第三章中主要介绍了简单的文件读取和简单的异常处理操作。
首先建立文件文件夹: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:文件读取和异常处理的更多相关文章
- python学习笔记(六)---文件操作与异常处理机制
文件读取 读取整个文件 要读取文件,需要一个包含几行文本的文件.下面首先来创建一个文件,它包含精确到小数点后30位的圆周率值,且在小数点后每10位处都换行: pi_digits.txt 3.14159 ...
- Python学习笔记之文件处理
1.打开和关闭 要打开文件可以使用函数 open(),它位于自动导入模块 io 中.函数将文件名作为唯一不可缺少的函数,并返回一个文件对象.它还有一个名叫 mode 的参数,用于指定文件模式,其可取值 ...
- [Python学习笔记]组织文件
shutil 模块 shutil 模块可以让我们很方便的在Python程序中复制.移动.改名和删除文件. 复制文件和文件夹 使用shutil.copy()来复制文件,该函数含两个参数,均为字符串格式的 ...
- 转载-Python学习笔记之文件读写
Python 文件读写 Python内置了读写文件的函数,用法和C是兼容的.本节介绍内容大致有:文件的打开/关闭.文件对象.文件的读写等. 本章节仅示例介绍 TXT 类型文档的读写,也就是最基础的文件 ...
- python学习笔记(11):文件的访问与函数式编程
一.文本文件读写的三种方法 1.直接读入 file1 = open('E:/hello/hello.txt') file2 = open('output.txt','w') #w是可写的文件 whil ...
- python学习笔记(7)文件的访问与函数式编程
一.文件读写的3中方法 1.直接读入 fiel1=open('test.txt') file2=open('output.txt') while True: line=file1.readLine() ...
- Python学习笔记9—文件
打开文件
- Python学习笔记六--文件和输入输出
6.1文件对象 所有Python对文件的操作都是基于对文件对象的操作.那么就从文件对象的创建说起.open()[file()]提供初始化输入输出的接口.open()成功打开文件时会返回一个文件对象. ...
- Python学习笔记 - day5 - 文件操作
Python文件操作 读写文件是最常见的IO操作,在磁盘上读写文件的功能都是由操作系统提供的,操作系统不允许普通的程序直接操作磁盘(大部分程序都需要间接的通过操作系统来完成对硬件的操作),所以,读写文 ...
随机推荐
- kruskal - 倍增 - 并查集 - Luogu 1967 货车运输
P1967 货车运输 题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物, 司机们想知道每辆车在不超过 ...
- chardet的下载及安装
1.chardet下载地址 https://pypi.python.org/pypi/chardet/3.0.4#downloads 2.解压至安装路径 D:\Program Files (x86)\ ...
- Leetcode 451.根据字符出现频率排序
根据字符出现频率排序 给定一个字符串,请将字符串里的字符按照出现的频率降序排列. 示例 1: 输入: "tree" 输出: "eert" 解释: 'e'出现两次 ...
- 聊聊、Nginx GDB与MAIN参数
接着上一篇,我们学习 Nginx 的 main 方法.用 gdb 工具调试 Nginx,首先 gdb nginx.如下: gdb 调试工具有很多的命令,上一篇为了找 main 方法用了 b 命令,也就 ...
- Iterator设计模式--jdk1.7
参照:http://www.cnblogs.com/tstd/p/5049338.html java.util.Iterator<E>是一个接口,它的定义如下: public interf ...
- OpenCV For Java环境搭建与功能演示
http://blog.csdn.net/jia20003/article/details/68944486
- 一步一步,完成sparkMLlib对日志文件的处理(1)
https://blog.csdn.net/u012834750/article/details/81014997 初学第一天,当然是完成helloWorld啦,有点艰难,2个小时,在idea, ...
- 【bzoj3698】XWW的难题 有上下界最大流
题目描述 XWW是个影响力很大的人,他有很多的追随者.这些追随者都想要加入XWW教成为XWW的教徒.但是这并不容易,需要通过XWW的考核.XWW给你出了这么一个难题:XWW给你一个N*N的正实数矩阵A ...
- mybatis学习(八)——resultMap之association&&collection解析
一.resultMap的使用 resultMap 也是定义返回值类型,返回值为用户自定义的类型,可用于解决JavaBean中的属性名和数据库中的列名不一致的情况 之前对于JavaBean中属性名和数据 ...
- Windows cmd 生成目录结构 dir /b,tree /f,xcopy
>dir *.sh *.ksh *.java /s/b > list.txt >tree /f > list.txt >xcopy C:\folder\from_fold ...