【python】错误、异常和文件---复习笔记

错误、异常和文件

1. 异常处理

错误指的是代码有语法问题,无法解释运行,必须改正后才能运行

如果代码没有语法问题,可以运行,但会出运行时的错误,例如除零错误,下标越界等问题,这种在运行期间检测到的错误被称为异常 ,出现了异常必须处理否则程序会终止执行,用户体验会很差。Phthon支持程序员自己处理检测到的异常。可以使用try-except语句进行异常的检测和处理

1.1 try-except语句

语法:try:【代码块A】 #可能会出错误的代码    异常检测except Exception1[ as e]:   #异常处理【代码块1】  #异常处理代码       except Exception2[ as e]:   #异常处理【代码块2】  #异常处理代码....except Exceptionn[ as e]:   #异常处理【代码块n】  #异常处理代码[else:]                #可选,如果没有引发异常会执行处理语句       [finally:]             #无论如何都要执行的语句处理语句【后续语句】
  • 执行流程:

    • 1、首先执行try中【代码块A】,如果出现异常,立即终止代码执行,转而到except块中进行异常处理

    • 2、异常处理except模块可以多个,从上往下匹配,如果能够匹配成功,立即执行相应的异常处理代码块,执行完毕后,不在往下匹配,转到3执行

    • 3、执行异常处理完毕后,如果有finally字句则执行finally字句,如果没有则执行【后续语句】

    • 4、如果匹配不到异常,有finally则执行finally,然后则抛出错误,终止程序执行。

    • 5、如果没有异常,如果有else字句则执行else字句,执行完else后,有finally字句则执行,没有则执行【后续语句】

  • 注意事项:

    • except匹配顺序从上到下

    • except语句书写要求:精确的类型往前放,模糊的,不精确的往后放

    • except不带任何类型,则匹配所有类型异常,应该放到最后,吞掉异常

    • 可以将多种异常用元组的方式(异常类型1,异常类型2...异常类型n)书写,简化代码

    • except字句中e,是一个对象,打印它,会显示异常信息描述

    • try-except也可以捕获方法或函数中抛出的异常

    • 所有异常类型都继承自BaseException,使用BaseException可以将异常一网打尽

    • finally字句中可以进行一些清理工作,比如关闭文件,数据库等工作

1.3 抛出异常

手动抛出一个指定类型的异常,无论是哪种异常类都可以带一个字符串参数,对异常进行描述。

  • raise不带参数会把错误原样抛出

try:raise ZeroDivisionError('除0错误')# raise ZeroDivisionError  #如果不想获取错误信息,可以不带参数
except ZeroDivisionError as e:print(e)  #除0错误

1.4 异常嵌套

在try块和excep块中还可以分别再嵌套try-except块

1.5 assert断言

语法:assert 条件 [,异常描述字符串]

执行流程:如果条件为假,则抛出AssertionError,条件为真,就当assert不存在

作用:对于可能出问题的代码,加上断言,方便问题排查

print('start')
num = int(input('请输入一个1~9的整数:'))
assert 0 <num <=9,'num不在1~9'
print('end')

1.6 自定义异常类

如果系统异常类型满足不了业务需求,那么可以自己定义异常类来处理。

  • 自己定义的异常类必须继承BaseException或Exception

  • 步骤:

    • 在自定义异常类的构造函数中,调用父类构造函数

    • 重写__str__方法输出异常信息

    • 编写异常处理方法处理异常

class CustomError(BaseException): #继承BaseExceptiondef __init__(self,msg):super().__init__()  #调用父类初始化self.msg = msg#重写__str__,输出异常信息def __str__(self):return self.msg#3.自定义异常处理方法def handle_exception(self):print('异常处理')try:raise CustomError('自定义异常')
except CustomError as e:print(e)

 

2. 文件处理

文件的处理包括读文件和写文件,读写文件就是请求操作系统打开一个文件对象,然后,通过操作系统提供的接口从这个文件对象中读取数据(读文件),或者把数据写入这个文件对象(写文件)。

2.1 文件读取

文件读取可分为以下步骤:

  • 打开文件

  • 读取文件内容

  • 关闭文件

打开文件要使用open内建函数:

open(file [, mode='r', encoding=None, errors=None])

参数说明: file:文件路径,可以是相对路径和绝对路径

mode:文件打开模式

encodeing: 文件编码方式,不用于二进制文件,一般是utf-8,gbk

errors:指定如何处理编码和解码错误 ,适用于文本文件

返回值:一个可迭代的文件对象

mode解释
r只读
w只写,写之前会清空文件的内容,如果文件不存在,会创建新文件
a追加的方式,在原本内容中继续写,如果文件不存在,则会创建新文件
r+可读可写
w+打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a+打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
brb、wb、ab、rb+、wb+、ab+意义和上面一样,用于二进制文件操作

注意:二进制文件一般用于视频、音频、图片

读取文件常用函数:

函数解释
read([size])读取文件(读取size字符,默认读取全部)
readline([size])读取一行,如果指定size,将读入指定的字符数
readlines()把文件内容按行全部读入,返回一个包含所有行的列表
#打开文件
fp = open('qfile.txt','r',encoding='utf-8') 
​
#读取文件全部内容
#content = fp.read()  
#print(content)
​
#读取指定字符数,包括行尾的换行符\n
# print(fp.read(20))
​
#读取一行
# print(fp.readline(5))  #读取指定字符数
# print(fp.readline())  #读取一整行,直到碰到一个\n
​
#读取所有行,返回列表
# print(fp.readlines())  
​
#关闭文件
fp.close() 
#由于文件读写时都有可能产生IOError,一旦出错,后面的f.close()就不会调用。
# 所以,为了保证无论是否出错都能正确地关闭文件,我们可以使用try ... finally来实现:
# try:
#     fp = open('qfile.txt','r',encoding='utf-8')
#     print(fp.readlines())
# finally:
#     fp.close()
#可以简写为:
#with语句会自动调用close方法关闭文件
with open('qfile.txt','r',encoding='utf-8')  as fp:print(fp.readline())
#fread()和freadlines()会一次读入文件全部内容,如果文件太大,会直接耗尽内存的,因为文件对象可迭代,所以可以用for循环遍历文件读取
with open('qfile.txt','r',encoding='utf-8')  as fp:for line in fp:print(line.strip())   #注意无论是read、readline、readlines都会读入行末的\n,所以需要手动剔除\n

2.2 写文件

path = "file11.txt"
​
#1.打开文件
f = open(path,"w",encoding="utf-8")
​
#2.写入内容,将内容写入到缓冲区
#不会自动换行,需要换行的话,需要在字符串末尾添加换行符
f.write("Whatever is worth doing is worth doing well该行很骄傲很关键\n")
​
​
#3.刷新缓冲区【加速数据的流动,保证缓冲区的流畅】
f.flush()
​
#4.关闭文件  关闭文件也会刷新缓冲区
f.close()
​
#简写方式:可以不用手动调用close
with open(path,"w",encoding="utf-8") as f1:f.write("Whatever is worth doing is worth doing well该行很骄傲很关键")

 

2.3 移动文件指针

文件是顺序向后读写的,如果想要移动文件指针,可以使用seek方法:

file_obj.seek(offset,whence=0)

功能:移动文件指针

参数:offset 是偏移量,正数表示从文件开头向文件末尾移动,负数相反。

whence : 文件指针的位置,可选参数,值可以是

SEEK_SET or 0 表示文件开头位置,是默认值

SEEK_CUR or 1 表示当前位置(不能使用)

SEEK_END or 2 文件末尾位置(不能使用)

返回值:无

#1.txt内容:hello world
with open('1.txt','r',encoding='utf-8') as fp:fp.seek(5)  #移动到hello后的空格位置print(fp.read(3))  #wofp.seek(0)   #移动到开头print(fp.read(5))  #helloprint(fp.tell())   #tell()显示当前指针位置

3.CSV文件操作

逗号分隔值(Comma-Separated Values,CSV),其文件以纯文本形式存储表格数据(数字和文本),文件的每一行都是一个数据记录。每个记录由一个或多个字段组成,用逗号分隔。使用逗号作为字段分隔符是此文件格式的名称的来源,因为分隔字符也可以不是逗号,有时也称为字符分隔值。

在Windows下,csv文件可以通过记事本,excel,notepad++,editplus等打开

  • 作用:CSV广泛用于不同体系结构的应用程序之间交换数据表格信息,解决不兼容数据格式的互通问题。

  • 需要导入csv模块

3.1 读取csv

import csv
with open(r'csv\winequality-red.csv') as fp:  #1.打开文件#delimiter指定分隔符csv_reader = csv.reader(fp,delimiter=';')  #2.获取csv读取器header = next(csv_reader) #获取第一行的标题print(header)for line in csv_reader: #3.遍历所有的行print(line)

3.2 写入csv

import csv
l1 = [[1,2,3],[4,5,6],[7,8,9]]
#打开文件时,要添加newline=''参数,否则会多一个空行
with open('1.csv','w',newline='') as fp: #1.打开文件#delimiter='\t'指定数据分隔符csv_writer = csv.writer(fp,delimiter='\t')  #2.获取writerfor line in l1:csv_writer.writerow(line)  #3.写入文件

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/456635.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

关于使用百度ueditor时的一些问题

本来这些问题直接在百度贴吧里回答不就完事了,可是好死不死的,百度贴吧里老出现 未知错误&#xff0c;错误号&#xff1a;230274 看来还是算了,自己做一个随笔记录一下好了 关于我们获取里面的内容时,老是会有一个<p>来包着,而且还老是多出来一个<br/> 这边是这么处…

Storm的通信机制

目录前言&#xff1a;1、Worker进程间通信原理2、Worker进程间技术(Netty、ZeroMQ)3、Worker 内部通信技术(Disruptor)总结&#xff1a; 目录 前言&#xff1a; 这篇文章&#xff0c;博客主要介绍下Storm中Worker进程间和进程内部通信的原理和技术。整篇内容仅供了解&#x…

《Windows PowerShell实战指南(第2版)》——1.4 搭建自己的实验环境

本节书摘来自异步社区《Windows PowerShell实战指南&#xff08;第2版&#xff09;》一书中的第1章&#xff0c;第1.4节&#xff0c;作者&#xff1a;【美】Don Jones&#xff08;道琼斯&#xff09; , Jeffery Hicks&#xff08;杰弗瑞希克斯&#xff09;著&#xff0c;更多章…

已解决]求问not 1 or 0 and 1 or 3 and 4 or 5 and 6 or 7 and 8 and 9为什么不等于0呢???

not 1 or 0 and 1 or 3 and 4 or 5 and 6 or 7 and 8 and 9 ----> (not 1&#xff09;)or (0 and 1) or (3 and 4) or (5 and 6) or (7 and 8 and 9) ----> 0 or 0 or 4 or 6 or 9 ----> 0 or 4 or 6 or 9 ----> 4 or 6 or 9 4

C#外围工具资源

1、MATH.NET数学库:可以用于 矩阵计算方程求根插值拟合。。。2、转载于:https://www.cnblogs.com/liq07lzucn/p/6227443.html

Storm程序的并发机制原理总结

文章目录目录前言&#xff1a;1、概念2、配置并行度总结&#xff1a;目录 前言&#xff1a; 为了在以后的实践中提高Storm程序执行的效率&#xff0c;我们还是有必要了解下对应的Storm程序的并发机制。&#xff08;哈哈&#xff0c;虽然以博主小菜鸟的水平还没有接触到这种提…

《无线网络:理解和应对互联网环境下网络互连所带来的挑战》——第2章 无线生态系统 2.1无线标准化过程...

本节书摘来自华章出版社《无线网络&#xff1a;理解和应对互联网环境下网络互连所带来的挑战》一书中的第2章&#xff0c;第2.1节&#xff0c;作者&#xff1a;&#xff08;美&#xff09;杰克L.伯班克&#xff08;Jack L. Burbank&#xff09;等著&#xff0c;更多章节内容可以…

Flask模板01

模板 在前面的示例中&#xff0c;视图函数的主要作用是生成请求的响应&#xff0c;这是最简单的请求。实际上&#xff0c;视图函数有两个作用&#xff1a;处理业务逻辑和返回响应内容。在大型应用中&#xff0c;把业务逻辑和表现内容放在一起&#xff0c;会增加代码的复杂度和…

★数学上最大的数是多少?

数学上最大的数是多少&#xff1f; 怪罗科普 收藏(282)| 阅读(117678)人类已经使用数长达千年之久。普遍认为&#xff0c;数的概念最先源于史前人类开始使用手指进行计数。这最终演变成符号语言&#xff0c;然后在沙子、墙壁和木头等物体上作标记。 我们已经向前发展了一大步&…

Flask模板02

3.4 控制语句 常用的几种控制语句&#xff1a; 模板中的if控制语句 app.route(/user) def user():user dongGereturn render_template(user.html,useruser)<html><head>{% if user %}<title> hello {{user}} </title>{% else %}<title> welc…

Storm任务提交过程及目录树介绍

目录前言&#xff1a;1、Storm 任务提交的过程2、Storm相关的目录树总结&#xff1a; 目录 前言&#xff1a; 对于任何一个组件来说&#xff0c;了解它相关的任务提交的过程是非常有必要的&#xff08;毕竟生产中遇到一些Bug时&#xff0c;你如果知道内部执行的过程&#xf…

《Adobe InDesign CS6中文版经典教程》—第1课1.5节修改文档的缩放比例

本节书摘来自异步社区《Adobe InDesign CS6中文版经典教程》一书中的第1课1.5节修改文档的缩放比例&#xff0c;作者【美】Adobe公司,更多章节内容可以访问云栖社区“异步社区”公众号查看。 1.5 修改文档的缩放比例Adobe InDesign CS6中文版经典教程InDesign中的控件让用户能…

随机生成一定范围的随机数

function randomNum(min,max) { return Math.ceil(Math.random()*(max-min)min); } min,max最小最大范围数字。转载于:https://www.cnblogs.com/kingzlz/p/6229586.html

【python】Flask视图

2.1 从 Hello World 开始 Flask程序运行过程&#xff1a; 所有Flask程序必须有一个程序实例。 Flask调用视图函数后&#xff0c;会将视图函数的返回值作为响应的内容&#xff0c;返回给客户端。一般情况下&#xff0c;响应内容主要是字符串和状态码。 当客户端想要获取资源…

大数据之Kafka入门简介

目录前言&#xff1a;1、Kafka是什么2、JMS是什么3、Kafka核心组件&#xff08;重点&#xff09;总结&#xff1a; 目录 前言&#xff1a; 作为流式计算中的一个组件&#xff0c;对于它的组成以及运行的原理&#xff0c;学习者也需要相关的了解。以下主要简单介绍了kafka是什…

oracle的安装与plsql的环境配置

1&#xff0c;首先得有oracle的安装包和plsql的安装包&#xff0c;安装包地址可见百度云 http://pan.baidu.com/s/1miTqhmg 2.解压下来进入0817账套&#xff0c;找到set.exe文件&#xff0c;双击安装即可 注意的是安装的时候有两个目录是要自己创建的&#xff0c;否则安装不成功…

如何在Docker容器中运行GUI程序

如何在Docker容器中运行GUI程序 各位&#xff0c;今天我们将学习如何在Docker之中运行GUI程序。我们可以轻易地在Docker容器中运行大多数GUI程序且不出错。Docker是一个开源项目&#xff0c;提供了一个打包、分发和运行任意程序的轻量级容器的开放平台。它没有语言支持、框架或…

【python】Get与Post的区别?(面试官最想听到的答案)

GET和POST是HTTP请求的两种基本方法&#xff0c;要说它们的区别&#xff0c;接触过WEB开发的人都能说出一二。 最直观的区别就是GET把参数包含在URL中&#xff0c;POST通过request body传递参数。 你可能自己写过无数个GET和POST请求&#xff0c;或者已经看过很多权威网站总结出…

大数据之Kafka集群安装及简单使用

目录1、Kafka集群部署2、Kafka常用操作命令 目录 1、Kafka集群部署 1.1、下载安装包 http://kafka.apache.org/downloads.html 在linux中使用wget命令下载安装包 wget http://mirrors.hust.edu.cn/apache/kafka/0.8.2.2/kafka_2.11-0.8.2.2.tgz 1.2、解压安装包 tar -z…

Python爬虫入门之Urllib库的基本使用

那么接下来&#xff0c;小伙伴们就一起和我真正迈向我们的爬虫之路吧。 1.分分钟扒一个网页下来 怎样扒网页呢&#xff1f;其实就是根据URL来获取它的网页信息&#xff0c;虽然我们在浏览器中看到的是一幅幅优美的画面&#xff0c;但是其实是由浏览器解释才呈现出来的&#xf…