笔记主要由来于 慕课网 Python 语言程序设计
1.文件的理解
2.文件的打开关闭
3.文件内容的读取
- 数据的文件写入
1.文件的理解
文件是数据的抽象和集合
- 文件是存储在辅助存储器上的数据序列
- 文件是数据存储的一种形式
- 文件展现形态:文本文件和二进制文件
文本文件 vs. 二进制文件
- 文本文件和二进制文件只是文件的展示方式
- 本质上,所有的文件都是二进制形式存储
- 形式上,所有文件采用两种方式展示
1.1文本文件
文件是数据的抽象和集合
- 由单一特定编码组成的文件,如 UTF-8编码
- 由于存在编码,也被看成是存储这的长字符串
- 适用于例如:.txt文件、.py文件
1.2二进制文件
- 直接由比特0和1组成,没有统一字符编码
- 一般存在二进制0和1的组织结构,即文件格式
- 适用于例如:.png文件、 .avi文件等
2.文件的打开关闭
文件处理的步骤:打开---操作---关闭
2.1文件的打开
<变量名> = open(<文件名>,<打开模式>)
变量名:文件句柄(文件抽象变量)
文件名:文件路径和名称(源文件用目录可以省略)
打开模式:文本 or 二进制 读信息 or 写信息
文件路径
<变量名> = open(<文件名>,<打开模式>)
文件位置:
D:\PythonPractice\.idea\Practice\f.txt
文件名:(源文件同目录可省略路径)
绝对路径
"D:\\PythonPractice\\.idea\\Practice\\f.txt"
或 "D:/PythonPractice/.idea/Practice/f.txt"
相对路径:(打开的文件与当前程序之间的路径)
若当前的程序存储在D盘根目录下
"./PythonPractice/.idea/Practice/f.txt"
打开文件和当前程序在相同目录下
"f.txt"
2.2打开模式
'r' 只读模式,默认值,如果文件不存在,则返回FileNotFoundError(使用try expect 捕捉处理)
'w' 覆盖模式,文件不存在则创建文件,存在则完全覆盖
'x' 创建写模式,文件不存在则创建,存在则返回FilExistssError
'a' 追加写模式,文件不存在则创建,存在则在文件最后追加内容,不会更改文件之前内容
'b' 二进制文件模式
't' 文本文件,默认值
'+' 与 r/w/x/a 一同使用,在原功能基础上增加同时读写功能
f = open("f.txt") - 文本形式、只读模式、默认值
f = open("f.txt", "rt") - 文本形式、只读模式、通默认值
f = open("f.txt", "w") - 文本形式、覆盖写模式
f = open("f.txt", "a+") - 文本形式、追加写模式 + 读文件
f = open("f.txt", "x") - 文本形式、创建写模式
f = open("f.txt", "b") - 二进制形式、只读模式
f = open("f.txt", "wb") - 二进制模式、覆盖写模式
2.3文件的关闭
<文件名> .colse()
若不写此句话,程序执行时此文件处于打开状态,程序退出时python解释器会关闭此文件
3.文件内容的读取
<f>.read(size = -1) 读取全部内容,如果给出参数,读入前size长度
<f>.readline(size= -1) 读入一行内容,如果给出参数,读入改行前size长度
<f>.readlines(hint= -1) 读入文件所有行,以每行为元素形成列表,如果给出参数,读入前hint行
>>> tf = open("D:/PythonPractice/.idea/Practice/f.txt","rt")
>>> a = tf.read()
>>> print(a)
中国是一个伟大的国家!
世界和平!
>>> tf = open("D:/PythonPractice/.idea/Practice/f.txt","rt")
>>> s = tf.read(2)
>>> print(s)
中国
>>> tf = open("D:/PythonPractice/.idea/Practice/f.txt","rt")
>>> a = tf.readline()
>>> print(a)
中国是一个伟大的国家!
>>> tf = open("D:/PythonPractice/.idea/Practice/f.txt","rt")
>>> s1 = tf.readline(5)
>>> print(s1)
中国是一个
>>> f = open("D:/PythonPractice/.idea/Practice/f.txt","rt")
>>> c = tf.readlines()
>>> print(c)
['伟大的国家!\n', '世界和平!']
>>> f = open("D:/PythonPractice/.idea/Practice/f.txt","rt")
>>> s2 = f.readlines(2)
>>> print(s2)
['中国是一个伟大的国家!\n']
3.1遍历全体文本
# 遍历全文本:方法一
fname = input("请输入要打开的文件名称:")
fo = open(fname, "r")
txt = fo.read()
# 对文本txt进行处理
fo.close()
# 一次读入,统一处理
# 弊端:大文件,一次读入内存,浪费时间资源
# 遍历全文本:方法一
fname = input("请输入要打开的文件名称:")
fo = open(fname, "r")
txt = fo.read(2)
while txt != "":
# 对txt进行处理
txt = fo.read(2)
fo.close()
# 按数量读入,分阶段,逐步处理
3.2逐行遍历文件
# 逐行遍历文件 :方法一
fname = input("请输入要打开的文件名称:")
fo = open(fname,"r")
for line in fo.readlines():
print(line)
fo.close()
# 一次读入,分行处理
# 逐行遍历文件 :方法二
fname = input("请输入要打开的文件名称:")
fo = open(fname,"r")
for line in fo:
print(line)
fo.close()
# 分行读入,逐步处理
4. 数据的文件写入
<f>.write(s) 向文件写入一个字符串或字节流
<f>.writdlines(lines) 将一个元素为字符串的列表写入文件
<f>.seek(offset) 改变当前文件操作指针的位置,
offset:0 文件开头
1 当前位置
2 文件结尾
fo = open("output.txt","w+")
ls = ["中国","法国","美国"]
fo.writelines(ls)
fo.seek(0)
for line in fo :
print(line)
fo.close()
中国法国美国
网友评论