python 文件操作不被打断_python学习六文件操作和异常处理

1.文件的定义和类型

什么是文件呢?

文件是数据的抽象和集合

文件是存储在辅助存储器上的数据序列

文件是存储的一种

文件有哪些类型呢?

本质上所有文件以二进制储存,不过又可以分为文本文件和二进制文件

文本文件时由单一特定编码组成,如UTF-8编码用于txt、py文件

二进制文件直接由比特0和1组成,没有统一的字符编码,如png图片文件,avi视频文件

2.文件处理步骤

文件处理可以分为三大步:

文件的打开

文件的具体操作

文件的关闭

3.文件的打开和关闭

文件打开有两种方式:

1.直接采用open(文件名称)打开

fileName = open('test1.txt')#注意:文件名称可以是文件相对与当前程序的路径,称为相对路径;#也可以是文件相对于电脑的路径,称为绝对路径。

2.采用with… as… 打开

filename = 'test1'with open(filename) as f:#文件操作代码

文件的关闭:

文件打开后必须关闭文件。不过在python解析器中,当程序关后会自动关闭文件。

文件关闭语法 变量名.close()

fileName = open('test1.txt')#文件操作代码

filename.close()

需要注意的是,采用with…as…方式打开的文件就不用我们在写关闭文件的代码。with…as…会自动在文件操作代码运行完成后关闭文件。

4.文件的操作

文件操作分为:读文件、写文件。

读文件:

读文件有三种操作方式,分别是:

file.read(size)

读入全部内容,默认size=-1,如果size=n则读入前size长度

file.readline(size)

读入一行内容,默认size=-1,如果给出参数,则读入该行前size长度的内容

file.readlines(hint)

读入文件所有行,以每行为元素形成列表,默认hibt=-1,如果给出参数,则读入前hint行

写文件:

有两种操作方式外加一种辅助操作:

1.file.write(s)

向文件协议一个字符串或字节流

f.write('中国是一个伟大的国家!')

2.file.writeline(lines)

将一个元素全位字符串的列表写入文件,字符串拼接后写入

ls = ['中国', '法国', '美国']

f.write(ls)#中国法国美国

3.file.seek(offset)

改变当前文件操作指针的位置,offset含义如下:

0-文件开头;1-当前位置;2-文件结尾

f.seel(0)#回到文件开头

f.seel(1)#文件当前位置

f.seel(2)#回到文件结尾

文件写入和读取:

fo = opne('test1.txt', 'w+')

ls= ['中国', '法国', '美国']

fo.writelines(ls)

fo.seek(0) #回到文件开头for line info:print(line)

fo.close()

文件打开模式:

# “+”表示可以同时读写某个文件,如:r+读写、w+写读、x+写读、a+写读

fileName = open('test1.txt') #默认使用文本形式和只读模式打开文件fileName= open('test1.txt', 'rt')#文本制度模式打开文件fileName= open('test1.txt', 'w')#文本形式,覆盖写模式打开文件

fileName = open('test1.txt', 'a+')#文本形式,追加写模式+读文件

fileName = open('test1.txt', 'x')#文本形式、创建写模式

fileName = open('test1.txt', 'b')#二进制形式,只读模式

fileName = open('test1.txt', 'wb')#二进制形式,覆盖写模式fileName.close()

文件的全文本操作:

方法一:

fname = input('请输入要打开文件的名称:')

fo= open(fname, 'r')

txt=fo.read()#对全文本txt进行处理

fo.close()#一次读入,统一处理,文本文件内容大消耗大

方法二:

fname = input('请输入要打开文件的名称:')

fo= open(fname, 'r')

txt= fo.read(2) #每次最多读取2个字节的内容while txt != '':#对txt进行处理

txt = fo.read(2)

fo.close()#分阶段,按数量读入,逐步处理 处理大文件更加可行有效

分行储存的文件读写:逐行遍历文件

fname = input('请输入要打开文件的名称:')

fo= open(fname, 'r')for line info.readlines()print(line)

fo.close()

追加文件内容:

f=open('file.json','a')

f.write('wuya') #在file.json文件中追加 wuya

f.colse()

文件的上下文处理:

with open('file2','w') as f:

f.write('wuya')

5.异常处理

异常:在程序运行过程中,不可避免的出现一些错误 例如用没赋值的变量等。Python使用被称为异常的特殊对象来管理程序执行期间发生的错误。每当发生错误时,它都会创建一个异常对象,若编写了处理该异常的代码,程序将继续运行,

否则程序将停止,并显示一个traceback其中包含有关异常的报告。

异常处理语法:若try代码块中的代码运行起来没有问题,python将跳过except代码块;否则python将查找except代码块,并进行处理。而依赖于try代码块成功执行的代码都放在else代码块中。

如果出现错误时,对错误不进行任何处理,可使用pass语句,pass还充当了占位符,提醒你程序的某个地方还什么都没做,以后也许要添加些代码常见异常如: FileNotFoundError, ZeroDivisionError,ValueError。无法确定异常类型时,就用except Exception,可以捕获所有异常。

try的工作原理是,当开始一个try语句后,python就在当前程序的上下文中作标记,这样当异常出现时就可以回到这里,try子句先执行,接下来会发生什么依赖于执行时是否出现异常。

如果当try后的语句执行时发生异常,python就跳回到try并执行第一个匹配该异常的except子句,异常处理完毕,控制流就通过整个try语句(除非在处理异常时又引发新的异常)。

如果在try后的语句里发生了异常,却没有匹配的except子句,异常将被递交到上层的try,或者到程序的最上层(这样将结束程序,并打印默认的出错信息)。

如果在try子句执行时没有发生异常,python将执行else语句后的语句(如果有else的话),然后控制流通过整个try语句。

try:#可能出现异常的代码块

except:#出现异常后执行的代码块

else: #若try模块没问题,会执行的代码块

finally:#不管有没有异常都会执行的代码块

raise: #用于引发一个实际的异常,raise 可以单独作为语句使用,引发一个具体的异常对象;

除了处理实际的错误条件之外,对于异常还有许多其它的用处。在标准 Python 库中

一个普通的用法就是试着导入一个模块,然后检查是否它能使用。导入一个并不存在的

模块将引发一个 ImportError 异常。

try:

正常的操作

......................except(Exception1[, Exception2[,...ExceptionN]]]):

发生以上多个异常中的一个,执行这块代码

......................else:

如果没有异常执行这块代码

print('异常出现前')try:print(a)print(10/0)exceptException as e:#except后面如果跟异常对象则默认捕获所有异常#由于Exception是所有异常对象的父对象所以except后面跟Exception捕获所有异常

print(e,type(e))else:print('yi')finally:print('无论是否出现异常,finally都会执行')

异常的参数:一个异常可以带上参数,可作为输出的异常信息参数。

可以通过except语句来捕获异常的参数,如下所示:

try:

正常的操作

......................exceptExceptionType, Argument:

你可以在这输出 Argument 的值...

变量接收的异常值通常包含在异常的语句中。在元组的表单中变量可以接收一个或者多个值。

元组通常包含错误字符串,错误数字,错误位置。

抛出(触发)异常:可以使用raise语句自己触发异常

raise[Exception [, args [, traceback]]]#语句中 Exception 是异常的类型(例如,NameError)参数标准异常中任一种,args 是自已提供的异常参数。#最后一个参数是可选的(在实践中很少使用),如果存在,是跟踪异常对象。

#IndexError#NameError

classAgeError(ValueError):passage= 1000

if 0 < age < 150:print('age legal')else:raise AgeError('age error')

#!/usr/bin/python#-*- coding: UTF-8 -*-

try:

fh= open("testfile", "w")

fh.write("这是一个测试文件,用于测试异常!!")exceptIOError:print "Error: 没有找到文件或读取文件失败"

else:print "内容写入文件成功"fh.close()#输出结果

$ python test.py

内容写入文件成功

$ cat testfile # 查看写入的内容

这是一个测试文件,用于测试异常!!

用户自定义异常:

通过创建一个新的异常类,程序可以命名它们自己的异常。异常应该是典型的继承自Exception类,通过直接或间接的方式。

以下为与RuntimeError相关的实例,实例中创建了一个类,基类为RuntimeError,用于在异常触发时输出更多的信息。

在try语句块中,用户自定义的异常后执行except块语句,变量 e 是用于创建Networkerror类的实例。

classNetworkerror(RuntimeError):def __init__(self, arg):

self.args= arg

定义以上类后,可以触发该异常,如下所示:

try:raise Networkerror("Bad hostname")exceptNetworkerror,e:print e.args

python标准异常:

异常名称描述

BaseException

所有异常的基类

SystemExit

解释器请求退出

KeyboardInterrupt

用户中断执行(通常是输入^C)

Exception

常规错误的基类

StopIteration

迭代器没有更多的值

GeneratorExit

生成器(generator)发生异常来通知退出

StandardError

所有的内建标准异常的基类

ArithmeticError

所有数值计算错误的基类

FloatingPointError

浮点计算错误

OverflowError

数值运算超出最大限制

ZeroDivisionError

除(或取模)零 (所有数据类型)

AssertionError

断言语句失败

AttributeError

对象没有这个属性

EOFError

没有内建输入,到达EOF 标记

EnvironmentError

操作系统错误的基类

IOError

输入/输出操作失败

OSError

操作系统错误

WindowsError

系统调用失败

ImportError

导入模块/对象失败

LookupError

无效数据查询的基类

IndexError

序列中没有此索引(index)

KeyError

映射中没有这个键

MemoryError

内存溢出错误(对于Python 解释器不是致命的)

NameError

未声明/初始化对象 (没有属性)

UnboundLocalError

访问未初始化的本地变量

ReferenceError

弱引用(Weak reference)试图访问已经垃圾回收了的对象

RuntimeError

一般的运行时错误

NotImplementedError

尚未实现的方法

SyntaxError

Python 语法错误

IndentationError

缩进错误

TabError

Tab 和空格混用

SystemError

一般的解释器系统错误

TypeError

对类型无效的操作

ValueError

传入无效的参数

UnicodeError

Unicode 相关的错误

UnicodeDecodeError

Unicode 解码时的错误

UnicodeEncodeError

Unicode 编码时错误

UnicodeTranslateError

Unicode 转换时错误

Warning

警告的基类

DeprecationWarning

关于被弃用的特征的警告

FutureWarning

关于构造将来语义会有改变的警告

OverflowWarning

旧的关于自动提升为长整型(long)的警告

PendingDeprecationWarning

关于特性将会被废弃的警告

RuntimeWarning

可疑的运行时行为(runtime behavior)的警告

SyntaxWarning

可疑的语法的警告

UserWarning

用户代码生成的警告

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值