Python --- 文件的使用

2019-06-11  本文已影响0人  A_x_A

笔记主要由来于 慕课网 Python 语言程序设计

1.文件的理解
2.文件的打开关闭
3.文件内容的读取

  1. 数据的文件写入

1.文件的理解

文件是数据的抽象和集合

文本文件 vs. 二进制文件

1.1文本文件

文件是数据的抽象和集合

1.2二进制文件

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()

中国法国美国
上一篇 下一篇

猜你喜欢

热点阅读