python中的head函数读行失败_《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,等等。面对这些异常,有两种处理思路:

提前考虑好程序中可能出现的异常,对这些情况进行处理,从而避免异常的发生。

采用异常捕获机制:让异常发生,但是对异常进行捕获,捕获到后再进行相关的操作。

第一种思路:

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

如果觉得有用,欢迎关注我的微信,有问题可以直接交流:

wechat-qcode.jpg

你的关注是对我最大的鼓励!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值