我们经常需要从文件中读取数据,因此学会文件的读取很重要,下面来介绍一下文件的读取工作:

    1.读取整个文件

    pi_digits.text

3.1415926535

8979323846

2643383279

单纯的读取一个文件,我们首先要打开文件,然后读取里面的内容,使用read()方法,读取文件的全部内容,然后把读取出来的内容进行赋给一个变量;如下所示:

    file_reader.py

with open('pi_digits.text') as file_object:

contents = file_object.read()

print(type(contents))

    print(contents)

输出结果如下:

3.1415926535
    8979323846
    2643383279

      <class 'str'>

还有一种方法读取文件,我们来看看,直接打开然后进行读取,不使用with语句:

f = open('pi_digits.text')
  contents = f.read()
  print(contents)
  f.close()

这种方法直接读取文件,但是要记得关闭文件,我们要知道,我们操作的是什么,目的是什么,如果我们只是单纯的读取文件的内容,而不去修改它,那么就单纯使用open()方法,不用第二参数即可:

第一种方法中,with open('pi_digits.text') as file_object:做了大量的工作。我们先来看看open()。要以任何方式使用文件——哪怕仅仅打印其内容,都得先打开文件,这样才能够访问它,而且第一种方法读取之后,赋给变量contents,变量contents是一个字符串,不是列表,也不是元祖之类的,而只是单纯的字符串情况;第二种方法必须记得关闭文件。

文件的相对路径和绝对路径

这两种方法的区别:with在不再需要访问文件后将其关闭。在这个程序中,注意到我们调用了open(),但没有调用close();我们也可以调用open()和close()来打开和关闭文件(第二种方法),但这样做时,如果程序存在bug,导致close()语句未执行,文件将不会关闭。这看似微不足道,但未妥善地关闭文件可能会导致数据丢失或受损。如果在程序中过早地调用close(),我们会发现需要使用文件时它已关闭(无法访问),这会导致更多的错误。并非任何情况下都能轻松地确定文件的恰当时机,但通过使用前面所示的结构,可让Python去确定:我们只管打开文件,并在需要时使用它,Python自会在合适的时候自动将其关闭。

所以这两种方法都是可以的,只是with打开的方式更安全一些,不需要我们去确定什么时候关闭文件,而open()直接打开的话就需要我们自己去确定什么时候要关闭文件,要使用close()方法关闭文件。

    2.逐行读取

f = open("pi_digits.text")
  for line in f:
    print(line.strip())
  f.close()

我们使用open()和close()方式打开文件,这种情况下,我们一定要记得关闭文件,以免文件遭到破坏,我们打开文件,

也可以使用with语句打开文件,这种方法让我们避免使用close()语句,系统会自动帮助我们在合适的时机关闭文件,也不用担心异常的问题。

with open('pi_digits.text') as f:
    for line in f:
      print(line)
    我们使用with语句打开这个文件,并命名为f,然后遍历这个打开的文件,输出每一行。这样我们就可以实现按行读取的方法。

    3.把文件读取到一个列表中

with open('pi_digits.text') as f:
    lines = f.readlines()
    print(lines)

把文件读取到一个列表中,readlines()方法是从文件中读取每一行,并将其存储到一个列表中;接下来,该列表被存储到变量lines中;读取文件得到一个列表的方法,我们读取这个文件,并且得到一个列表

f = open("pi_digits.text")
  lines = f.readlines()
  print(lines)

f.close()

我们在直接使用open()打开文件的时候,一定要记得关闭文件,使用close()方法把文件关闭,这点可能经常会一不小心忘记,只记得打开文件,但是没有关闭文件。

二、写入文件

保存数据的最简单的方式之一是将其写入到文件中。

    write_message.py

with open('programming.text','w') as f:

    f.write("I love programming")

在这个示例中,调用open()时提供了两个实参。第一个实参也是要打开的文件的名称;第二个实参("w")告诉Python,我们要以写入模式打开这个文件。打开文件时,可指定读取模式('r')、写入模式('w')、附加模式('a')或者让我们能够读取和写入文件的模式('r+').如果我们省略了模式实参,Python将以默认的只读模式打开文件

读取和写入文件有两种方法,一种是with语句打开文件;另一种是open()和close()结合使用打开和读取文件。

我们要知道我们打开文件是做什么如果只是单纯的打开和读取文件,只需要open()即可;要是写入的话,就需要指定第二参数。默认省略参数的情况下是只读模式的。

写入的方式

(1)写入模式('r')

(2)附加模式('a')

  with open("pi_digits.text",'a') as f:
     f.write("I love you,too,Really\n")
       f.write("I also love finding meanting in large datasets.\n")
     f.write("I love to start to make success.")

写入模式('r')和附加模式('a')都是向文件中写入内容,不同的是写入模式要覆盖之前文件里面的内容。

如果我们要写入的文件不存在,函数open()将自动创建它。然而,以写入('w')模式打开文件时千万要小心,因为如果指定的文件已经存在,Python

将在返回文件对象前清空该文件。所以使用写入模式('w')的时候一定要小心。

Python——文件读取的更多相关文章

  1. python文件读取和写入案例

    python文件读取和写入案例  直接上代码吧 都是说明 百度上找了很多,最终得出思路 没有直接可以读取修改的扩展,只能先读取,然后复制一份,然后在复制出来的文件里面追加保存 然后删除读的那个,但是缺 ...

  2. Python文件读取和数据处理

    一.python文件读取 1.基本操作 读取文件信息时要注意文件编码,文件编码有UFT-8.ASCII或UTF-16等. 不过在python中最为常用的是UTF-8,所以如果不特别说明就默认UTF-8 ...

  3. Python 文件读取

    1. 最基本的读文件方法: # File: readline-example-1.py file = open("sample.txt") while 1: line = file ...

  4. python文件读取

    1.如何将一个“lessons.txt”文档一行行输出? myfile = file(‘lessons.txt’) for f in myfile.readlines(): print f myfil ...

  5. Python文件读取编码错误问题解决之(PyCharm开发工具默认设置的坑。。。)

    刚接触Python学习,正准备做个爬虫的例子,谁知道代码一开始就遇到了一个大坑,狂汗啊. 问题是这样的:我通过代码爬取了博客园首页的HTML代码并存入到blog.txt文件当中,然后准备读取出来之后进 ...

  6. Python文件读取常用方法

    1. 关于读取文件 f.read() 读取文件中所有内容 f.readline() 读取第一行的内容 f.readlines() 读取文件里面所有内容,把每行的内容放到一个list里面 注:因为文件指 ...

  7. 初识python 文件读取 保存

    上一章最后一题的答案:infors.sort(key=lambda x:x['age'])print(infors)--->[{'name': 'laowang', 'age': 23}, {' ...

  8. python --文件读取数据

    读取整个文件: 首先创建一个文件,例如我创建了一个t x t文件了. 然后我想读取这个文件了,我首先将上面的这个文件保存在我即将要创建的Python的文件目录下, 即读取文件成功. 解析: 函数ope ...

  9. 超级基础的python文件读取

    读取文件的两种方式: 1.使用os的open函数: import sys,os r=open("data1.txt","r+") fr=r.readlines( ...

随机推荐

  1. 使用mysql将手机号、身份证号等字段进行脱敏

    -- 脱敏姓名 UPDATE wb_person_message SET `name`=(if(LENGTH(name)>6,CONCAT(LEFT(name,1), '**' ),CONCAT ...

  2. [ZJOI2019]麻将(动态规划,自动机)

    [ZJOI2019]麻将(动态规划,自动机) 题面 洛谷 题解 先做一点小铺垫,对于一堆牌而言,我们只需要知道这\(n\)张牌分别出现的次数就行了,即我们只需要知道一个长度为\(n\)的串就可以了. ...

  3. openstack——删除网络

    #!/bin/bash #delete vm for vim in `nova list |awk '{if( NR > 2 ) {print $2}}'`;do nova delete $vi ...

  4. elasticsearch更改mapping(不停服务重建索引)

    转载地址:http://donlianli.iteye.com/blog/1924721?utm_source=tuicool&utm_medium=referral Elasticsearc ...

  5. MacBook 整个配置过程,供新入手MacBook的同学

    这里记录了MacBook 的整个配置过程,可供新入手MacBook和觉得MacBook比较难用的同学参考. 1. 外围拓展 笔记本电脑的特点是携带方便,缺点是屏幕太小,因此你首先需要再申请领用一个外接 ...

  6. 剑指Offer_编程题_20

    题目描述 从上往下打印出二叉树的每个节点,同层节点从左至右打印.   /* struct TreeNode { int val; struct TreeNode *left; struct TreeN ...

  7. 【asp.net】asp.net遍历Request的信息

    #需求: 在服务端获取从客户端发送过来的所有数据信息: #方案: 1.服务端代码 public void ProcessRequest(HttpContext context) { //打印所有参数信 ...

  8. VUE-开发工具VSCode

    VUE-开发工具之VSCode VSCode是微软出的一款轻量级代码编辑器,免费而且功能强大,对JavaScript和NodeJS的支持非常好,自带很多功能,例如代码格式化,代码智能提示补全.Emme ...

  9. phpstorm快捷键大全

    前言:这段时间换了编辑器,所以挺多命令也改变了 转载来自:https://www.jianshu.com/p/ffb24d61000d?utm_campaign=maleskine&utm_c ...

  10. makefile $@, $^, $<, $? 表示的意义

    ref:https://www.cnblogs.com/gamesun/p/3323155.html $@  表示目标文件$^  表示所有的依赖文件$<  表示第一个依赖文件$?  表示比目标还 ...