黑马程序员技术交流社区

标题: Python基础知识day07文件操作、综合应用(上) [打印本页]

作者: 小江哥    时间: 2018-9-14 11:01
标题: Python基础知识day07文件操作、综合应用(上)
本帖最后由 小江哥 于 2018-9-14 11:01 编辑

文件操作介绍

<1>什么是文件

示例如下:


<2>文件的作用

大家应该听说过一句话:“好记性不如烂笔头”。
不仅人的大脑会遗忘事情,计算机也会如此,比如一个程序在运行过程中用了九牛二虎之力终于计算出了结果,试想一下如果不把这些数据存放起来,相比重启电脑之后,“哭都没地方哭了”
可见,在把数据存储起来有做么大的价值
使用文件的目的:
就是把一些存储存放起来,可以让程序下一次执行的时候直接使用,而不必重新制作一份,省时省力

文件的打开与关闭

想一想:
如果想用word编写一份简历,应该有哪些流程呢?
1. 打开word软件,新建一个word文件
2. 写入个人简历信息
3. 保存文件
4. 关闭word软件
同样,在操作文件的整体过程与使用word编写一份简历的过程是很相似的
1. 打开文件,或者新建立一个文件
2. /写数据
3. 关闭文件

<1>打开文件

python,使用open函数,可以打开一个已经存在的文件,或者创建一个新文件
open(文件名,访问模式)
示例如下:
   
[Python] 纯文本查看 复制代码
 f = open('test.txt', 'w')
说明:
访问模式
说明
r
以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
w
打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a
打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
rb
以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。
wb
以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
ab
以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
r+
打开一个文件用于读写。文件指针将会放在文件的开头。
w+
打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a+
打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
rb+
以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
wb+
以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
ab+
以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。

<2>关闭文件
close( )
示例如下:
   
[Python] 纯文本查看 复制代码
# 新建一个文件,文件名为:test.txt
    f = open('test.txt', 'w')
    # 关闭这个文件
    f.close()


文件的读写

<1>写数据(write)

使用write()可以完成向文件写入数据
demo:
[Python] 纯文本查看 复制代码
f = open('test.txt', 'w')
f.write('hello world, i am here!')
f.close()
运行现象:
注意:
· 如果文件不存在那么创建,如果存在那么就先清空,然后写入数据


<2>读数据(read)

使用read(num)可以从文件中读取数据,num表示要从文件中读取的数据的长度(单位是字节),如果没有传入num,那么就表示读取文件中所有的数据
demo:
[Python] 纯文本查看 复制代码
f = open('test.txt', 'r')
content = f.read(5)
print(content)
print("-"*30)
content = f.read()
print(content)
f.close()
运行现象:

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


<3>读数据(readlines)

就像read没有参数时一样,readlines可以按照行的方式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素
[Python] 纯文本查看 复制代码
#coding=utf-8
f = open('test.txt', 'r')
content = f.readlines()
print(type(content))
i=1for temp in content:
    print("%d:%s"%(i, temp))
    i+=1
f.close()
运行现象:


<4>读数据(readline)


[Python] 纯文本查看 复制代码
#coding=utf-8
f = open('test.txt', 'r')
content = f.readline()
print("1:%s"%content)
content = f.readline()
print("2:%s"%content)
f.close()


想一想:

如果一个文件很大,比如5G,试想应该怎样把文件的数据读取到内存然后进行处理呢?


应用1:制作文件的备份

任务描述
· 输入文件的名字,然后程序自动完成对文件进行备份



参考代码
[Python] 纯文本查看 复制代码
# 提示输入文件
oldFileName = input("请输入要拷贝的文件名字:")
# 以读的方式打开文件
oldFile = open(oldFileName,'rb')
# 提取文件的后缀
fileFlagNum = oldFileName.rfind('.')if fileFlagNum > 0:
    fileFlag = oldFileName[fileFlagNum:]
# 组织新的文件名字
newFileName = oldFileName[:fileFlagNum] + '[复件]' + fileFlag
# 创建新文件
newFile = open(newFileName, 'wb')
# 把旧文件中的数据,一行一行的进行复制到新文件中for lineContent in oldFile.readlines():
    newFile.write(lineContent)
# 关闭文件
oldFile.close()
newFile.close()








作者: Yin灬Yan    时间: 2018-9-22 17:55
感谢分享 慢慢看 还真能懂




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2