《Python入门+Python爬虫》——3Day Python基础——python文件操作、错误与异常处理

Python学习版本: Python 3.X
观看:Python入门+Python爬虫+Python数据分析
在这里插入图片描述

5.文件操作

文件,就是把一些数据存放起来,可以让程序下一次执行的时候直接使用,而不必重新制作一份,省时省力。

5.1 文件打开与关闭

5.1.1 打开文件

在python,使用open函数,可以打开一个已经存在的文件,或者创建一个新文件
open(文件名,访问模式)
示例如下:

f = open('test.txt', 'w')
访问模式说明
r以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
w打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
rb以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。
wb以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
ab以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
r+打开一个文件用于读写。文件指针将会放在文件的开头。
w+打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a+打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
rb+以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
wb+以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
ab+以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。
5.1.2 关闭文件

close( )
示例如下:

# 新建一个文件,文件名为:test.txt
f = open('test.txt', 'w')
# 关闭这个文件
f.close()

5.2 文件读写

5.2.1 写数据(write)

使用write()可以完成向文件写入数据

f = open('test.txt', 'w')
f.write('hello world, i am here!')
f.close()

注意:

  • 如果文件不存在那么创建,如果存在那么就先清空,然后写入数据
5.2.2 读数据(read)

使用read(num)可以从文件中读取数据,num表示要从文件中读取的数据的长度(单位是字节),如果没有传入num,那么就表示读取文件中所有的数据
demo

f = open('test.txt', 'r')
content = f.read(5)
print(content)
print("-"*30)
content = f.read()
print(content)
f.close()

注意:

  • 如果open是打开一个文件,那么可以不用写打开的模式,即只写 open(‘test.txt’)
  • 如果使用读了多次,那么后面读取的数据是从上次读完后的位置开始的
5.2.3 读数据(readlines)

就像read没有参数时一样,readlines可以按照行的方式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素

f1 = open("test.txt","r")
content = f1.readlines();
print(type(content))
for temp in range(len(content)):
    print("%d:%s"%(temp,content[temp]))
f1.close()
5.2.4 读数据(readline)
#coding=utf-8
f = open('test.txt', 'r')
content = f.readline()
print("1:%s"%content)
content = f.readline()
print("2:%s"%content)
f.close()

5.3 文件的相关操作

有些时候,需要对文件进行重命名、删除等一些操作,python的os模块中都有这么功能

5.3.1 文件重命名

os模块中的rename()可以完成对文件的重命名操作
rename(需要修改的文件名, 新的文件名)

import os
os.rename("毕业论文.txt", "毕业论文-最终版.txt")
5.3.2 删除文件

os模块中的remove()可以完成对文件的删除操作
remove(待删除的文件名)

import os
os.remove("毕业论文.txt")
5.3.3 创建文件夹
import os
os.mkdir("张三")
5.3.4 获取当前目录
import os
os.getcwd()
5.3.5 改变默认目录
import os
os.chdir("../")
5.3.6 获取目录列表
import os
os.listdir("./")
5.3.7 删除文件夹
import os
os.rmdir("张三")

6.错误与异常

6.1 异常简介

看如下示例
当在只读模式打开一个不存在的文件时

print '-----test--1---'
open('123.txt','r')
print '-----test--2---

运行结果:
在这里插入图片描述
说明:

打开一个不存在的文件123.txt,当找不到123.txt 文件时,就会抛出给我们一个IOError类型的错误,No such file or directory:123.txt (没有123.txt这样的文件或目录)

异常:

当Python检测到一个错误时,解释器就无法继续执行了,反而出现了一些错误的提示,这就是所谓的"异常"

6.2 捕获异常 try…except…

看如下示例:

try:
	print('-----test--1---')
	open('123.txt','r')
	print('-----test--2---')
except IOError:
	pass

说明:

  • 此程序看不到任何错误,因为用except 捕获到了IOError异常,并添加了处理的方法
  • pass 表示实现了相应的实现,但什么也不做;如果把pass改为print语句,那么就会输出其他信息

在这里插入图片描述

  • 把可能出现问题的代码,放在try中
  • 把处理异常的代码,放在except中

6.3 except捕获多个异常

看如下示例

try:
	print num
except IOError:
	print('产生错误了')

想一想:

上例程序,已经使用except来捕获异常了,为什么还会看到错误的信息提示?

答:

except捕获的错误类型是IOError,而此时程序产生的异常为 NameError ,所以except没有生效

修改后的代码为:

try:
	print num
except NameError:
	print('产生错误了')

实际开发中,捕获多个异常的方式,如下:

#coding=utf-8
try:
	print('-----test--1---')
	open('123.txt','r') # 如果123.txt文件不存在,那么会产生 IOError 异常
	print('-----test--2---')
	print(num)# 如果num变量没有定义,那么会产生 NameError 异常
except (IOError,NameError):
#如果想通过一次except捕获到多个异常可以用一个元组的方式

注意:**
当捕获多个异常时,可以把要捕获的异常的名字,放到except 后,并使用元组的方式仅进行存储

6.4 获取异常的信息描述

在这里插入图片描述

6.5 捕获所有异常

在这里插入图片描述

6.6 try…finally…

try…finally…语句用来表达这样的情况:

在程序中,如果一个段代码必须要执行,即无论异常是否产生都要执行,那么此时就需要使用finally。 比如文件关闭,释放锁,把数据库连接返还给连接池等

import time
try:
    f= open("123.txt","r")
    try:
        while True:
            content = f.readline()
            if len(content)== 0:
                break
            time.sleep(2)
            print(content)
    finally:
        f.close()
        print("文件关闭")
except Exception as result:
    print("发生异常")

说明:

test.txt文件中每一行数据打印,但是我有意在每打印一行之前用time.sleep方法暂停2秒钟。这样做的原因是让程序运行得慢一些。在程序运行的时候,按Ctrl+c中断(取消)程序。

我们可以观察到KeyboardInterrupt异常被触发,程序退出。但是在程序退出之前,finally从句仍然被执行,把文件关闭。

作业:

  1. 应用文件操作的相关知识,通过Python新建一个文件gushi.txt,选择一首古诗写入文件中
  2. 另外写一个函数,读取指定文件gushi.txt,将内容复制到copy.txt中,并在控制台输出“复制完毕”。
  3. 提示:分别定义两个函数,完成读文件和写文件的操作
    尽可能完善代码,添加异常处理。

本人做法,定义了两个方法,
gushiWrite(copyname,gushiList)将gushiList写入到copyname文件中
filecopy(name,copy) 将文件name 内容复制到文件copy中
形参copyname name copy这里是文件名

#创建文件,将 gushilishi 写入文件中copyname
def gushiWrite(copyname,gushiList):
    try:
        file1 = open(copyname,"w",encoding='utf8')#防止输入汉字乱码
        try:
            file1.writelines(gushiList)
        finally:
            file1.close()
            print("古诗写入完毕")
    except Exception as  result:
        print(result)
        
#另写一个函数读取  name 复制到 copy 
def filecopy(name,copy):
    content =[]
    try:
        file2 = open(name,"r",encoding="utf8")
        try:
            content = file2.readlines()
            gushiWrite(copy,content)
        finally:
            file2.close()
            print("复制完毕")
    except Exception as result:
        print(result)

gushiList=["究天人之际\n","通古今之变\n","成一家之言"]
gushiWrite("gushi.txt",gushiList)
filecopy("gushi.txt","copy.txt")
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
尚硅谷是一个提供在线教育的学习平台,他们提供了Python爬虫相关教学课程。通过学习这些课程,你可以获得Python基础知识、前端基础知识、计算机网络基础以及爬虫原理等方面的知识Python基础教学可以参考B站尚硅谷的教学视频,这些视频可以帮助你建立起对Python的基本认识。而前端基础知识包括HTML、CSS和JavaScript的学习,它们分别代表网页的骨架、肌肉和皮肤,只有结合起来才能形成一个完整的网页。此外,你还可以通过学习计算机网络基础来理解HTTP和HTTPS、URL以及网页请求等内容。爬虫原理也是其中的一部分内容,它可以帮助你了解如何通过爬虫程序获取网页数据。所以,如果你对Python爬虫感兴趣,尚硅谷提供的Python爬虫课程可能是一个不错的选择。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [零基础自学python爬虫笔记Day1——爬虫的基本原理](https://blog.csdn.net/Seyhang/article/details/119420052)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [【Python爬虫】urllib库——尚硅谷](https://blog.csdn.net/qq_48108092/article/details/126097408)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值