Python基础语法第七章之文件

简介: 一个机器上, 会存在很多文件, 为了让这些文件更方面的被组织, 往往会使用很多的 "文件夹"(也叫做目录)来整理文件,实际一个文件往往是放在一系列的目录结构之中的,为了方便确定一个文件所在的位置, 使用 文件路径 来进行描述。描述一个文件的位置, 使用 绝对路径 和 相对路径 都是可以的. 对于新手来说, 使用 绝对路径 更简单更好理解, 也不容易出错.. 相对路径需要先指定一个基准目录, 然后以基准目录为参照点, 间接的找到目标文件. 咱们课堂上暂时不详细介绍.使用 close 方法关闭已经打开的文件.

 目录

一、文件

1.1文件是什么

1.2文件路径

1.3文件操作

1.3.1 打开文件

1.3.2关闭文件

1.3.3写文件

1.3.4读文件

二、使用上下文管理器

2.1上下文管理器


一、文件

1.1文件是什么

变量是把数据保存到内存中. 如果程序重启/主机重启, 内存中的数据就会丢失.

要想能让数据被持久化存储, 就可以把数据存储到硬盘中. 也就是在 文件 中保存.

在 Windows "此电脑" 中, 看到的内容都是 文件.

image.gif编辑

通过文件的后缀名, 可以看到文件的类型. 常见的文件的类型如下:

    • 文本文件 (txt)
    • 可执行文件 (exe, dll)
    • 图片文件 (jpg, gif)
    • 视频文件 (mp4, mov)
    • office 文件 (.ppt, docx)
    • ......

    1.2文件路径

    一个机器上, 会存在很多文件, 为了让这些文件更方面的被组织, 往往会使用很多的 "文件夹"(也叫做目录)来整理文件,实际一个文件往往是放在一系列的目录结构之中的,为了方便确定一个文件所在的位置, 使用 文件路径 来进行描述。

    目录之间的分隔符, 可以使用 \ 也可以使用 / . 一般在编写代码的时候使用 / 更方便.

    上述以 盘符 开头的路径, 我们也称为 绝对路径.

    除了绝对路径之外, 还有一种常见的表示方式是 相对路径. 相对路径需要先指定一个基准目录, 然后以基准目录为参照点, 间接的找到目标文件. 咱们课堂上暂时不详细介绍.

    描述一个文件的位置, 使用 绝对路径 和 相对路径 都是可以的. 对于新手来说, 使用 绝对路径 更简单更好理解, 也不容易出错.

    1.3文件操作

    1.3.1 打开文件

    使用内建函数 open 打开一个文件.

    f = open('d:/test.txt', 'r')

    image.gif

      • 第一个参数是一个字符串, 表示要打开的文件路径
      • 第二个参数是一个字符串, 表示打开方式. 其中 r 表示按照读方式打开. w 表示按照写方式打开. a表示追加写方式打开.
      • 如果打开文件成功, 返回一个文件对象. 后续的读写文件操作都是围绕这个文件对象展开.
      • 如果打开文件失败(比如路径指定的文件不存在), 就会抛出异常.

      image.gif编辑

      1.3.2关闭文件

      使用 close 方法关闭已经打开的文件.

      f.close()

      image.gif

      使用完毕的文件要记得及时关闭!

      flist = []
      count = 0
      while True:
          f = open('d:/test.txt', 'r')
          flist.append(f)
          count += 1
          print(f'count = {count}')

      image.gif

      image.gif编辑

      如上面代码所示, 如果一直循环的打开文件, 而不去关闭的话, 就会出现上述报错.

      当一个程序打开的文件个数超过上限, 就会抛出异常.

      注意: 上述代码中, 使用一个列表来保存了所有的文件对象. 如果不进行保存, 那么 Python 内置的垃圾回收机制, 会在文件对象销毁的时候自动关闭文件.但是由于垃圾回收操作不一定及时, 所以我们写代码仍然要考虑手动关闭, 尽量避免依赖自动关闭.

      1.3.3写文件

      文件打开之后, 就可以写文件了.

        • 写文件, 要使用写方式打开, open 第二个参数设为 'w'
        • 使用 write 方法写入文件.
        f = open('d:/test.txt', 'w')
        f.write('hello')
        f.close()

        image.gif

        用记事本打开文件, 即可看到文件修改后的内容.

          • 如果是使用 'r' 方式打开文件, 则写入时会抛出异常.
          f = open('d:/test.txt', 'r')
          f.write('hello')
          f.close()

          image.gif

          image.gif编辑

            • 使用 'w' 一旦打开文件成功, 就会清空文件原有的数据.
            • 使用 'a' 实现 "追加写", 此时原有内容不变, 写入的内容会存在于之前文件内容的末尾.
            f = open('d:/test.txt', 'w')
            f.write('hello')
            f.close()
            f = open('d:/test.txt', 'a')
            f.write('world')
            f.close()

            image.gif

              • 针对已经关闭的文件对象进行写操作, 也会抛出异常.
              f = open('d:/test.txt', 'w')
              f.write('hello')
              f.close()
              f.write('world')

              image.gif

              1.3.4读文件

                • 读文件内容需要使用 'r' 的方式打开文件
                • 使用 read 方法完成读操作. 参数表示 "读取几个字符"
                f = open('d:/test.txt', 'r')
                result = f.read(2)
                print(result)
                f.close()

                image.gif

                  • 如果文件是多行文本, 可以使用 for 循环一次读取一行.
                  f = open('d:/test.txt', 'r')
                  for line in f:
                  print(f'line = {line}')
                  f.close()

                  image.gif

                  注意: 由于文件里每一行末尾都自带换行符, print 打印一行的时候又会默认加上一个换行符, 因此打印结果看起来之间存在空行.

                  使用 print(f'line = {line}', end='') 手动把 print 自带的换行符去掉.

                    • 使用 readlines 直接把文件整个内容读取出来, 返回一个列表. 每个元素即为一行.
                    f = open('d:/test.txt', 'r')
                    lines = f.readlines()
                    print(lines)
                    f.close()

                    image.gif

                    保证编码格式统一:f = open('d:/test.txt', 'r', encoding='utf8')


                    二、使用上下文管理器

                    2.1上下文管理器

                    打开文件之后, 是容易忘记关闭的. Python 提供了 上下文管理器 , 来帮助程序猿自动关闭文件.

                      • 使用 with 语句打开文件.
                      • 当 with 内部的代码块执行完毕后, 就会自动调用关闭方法.
                      with open('d:/test.txt', 'r', encoding='utf8') as f:
                          lines = f.readlines()
                          print(lines)

                      image.gif


                      目录
                      相关文章
                      |
                      3天前
                      |
                      Shell Python
                      Python Stock guess_indicators_daily_job.py文件的调整
                      Python Stock guess_indicators_daily_job.py文件的调整
                      12 1
                      |
                      3天前
                      |
                      XML 前端开发 数据格式
                      BeautifulSoup 是一个 Python 库,用于从 HTML 和 XML 文件中提取数据
                      BeautifulSoup 是 Python 的一个库,用于解析 HTML 和 XML 文件,即使在格式不规范的情况下也能有效工作。通过创建 BeautifulSoup 对象并使用方法如 find_all 和 get,可以方便地提取和查找文档中的信息。以下是一段示例代码,展示如何安装库、解析 HTML 数据以及打印段落、链接和特定类名的元素。BeautifulSoup 还支持更复杂的查询和文档修改功能。
                      11 1
                      |
                      1天前
                      |
                      Python
                      在Python中,利用`os模块`的`path.exists()`函数可判断文件是否存
                      在Python中,利用`os模块`的`path.exists()`函数可判断文件是否存在,该函数对路径进行检查,存在则返回True,不存在则返回False。示例代码展示了如何检查'example.txt'文件是否存在并相应打印消息。此外,`os.path.isfile()`用于确认路径是否为文件,仅当是文件时返回True,否则返回False,同样配以示例说明其用法。
                      8 2
                      |
                      3天前
                      |
                      Java C语言 C++
                      Python基础语法
                      Python基础语法
                      10 1
                      |
                      4天前
                      |
                      JSON 数据格式 索引
                      python之JMESPath:JSON 查询语法库示例详解
                      python之JMESPath:JSON 查询语法库示例详解
                      14 0
                      |
                      4天前
                      |
                      数据采集 NoSQL 中间件
                      python-scrapy框架(四)settings.py文件的用法详解实例
                      python-scrapy框架(四)settings.py文件的用法详解实例
                      9 0
                      |
                      4天前
                      |
                      存储 数据采集 数据库
                      python-scrapy框架(三)Pipeline文件的用法讲解
                      python-scrapy框架(三)Pipeline文件的用法讲解
                      7 0
                      |
                      6天前
                      |
                      缓存 数据处理 Python
                      python读取文件到缓存
                      python读取文件到缓存
                      12 1
                      |
                      7天前
                      |
                      存储 数据挖掘 Python
                      Python技术分享:实现选择文件或目录路径的方法
                      Python技术分享:实现选择文件或目录路径的方法
                      17 2
                      |
                      7天前
                      |
                      前端开发 JavaScript Python
                      使用Python读取本地行情csv文件,做出web网页画出K线图实现案例
                      【5月更文挑战第4天】使用Python绘制K线图的步骤:1) 安装pandas, matplotlib和Flask;2) 用pandas读取CSV文件并处理数据;3) 创建Flask应用,渲染包含K线图数据的HTML;4) 编写HTML,使用ECharts库绘制K线图。
                      26 0