一、打开文件

  1. # open(file, mode='r', buffering=-1, encoding_=None, errors=None, newline=None, closefd=True, opener=None)
  2. # 使用open函数来打开一个文件
  3. # 参数:
  4. # file 要打开的文件的名字(路径)
  5. # 返回值:
  6. # 返回一个对象,这个对象就代表了当前打开的文件
  7.  
  8. # 创建一个变量,来保存文件的名字
  9. # 如果目标文件和当前文件在同一级目录下,则直接使用文件名即可
  10. file_name = 'demo.txt'
  11.  
  12. # 在windows系统使用路径时,可以使用/来代替 \
  13. # 或者可以使用 \\ 来代替 \
  14. # 或者也可以使用原始字符串
  15. file_name = 'hello\\demo.txt'
  16. file_name = r'hello\demo.txt'
  17.  
  18. # 表示路径,可以使用..来返回一级目录
  19. file_name = '../hello/demo.txt'
  20.  
  21. # 如果目标文件距离当前文件比较远,此时可以使用绝对路径
  22. # 绝对路径应该从磁盘的根目录开始书写
  23. file_name = r'C:\Users\lilichao\Desktop\hello.txt'
  24.  
  25. # file_obj = open(file_name) # 打开 file_name 对应的文件
  26.  
  27. # print(file_obj)

关闭文件

  1. # 打开文件
  2. file_name = 'demo.txt'
  3.  
  4. # 调用open()来打开文件
  5. # file_obj = open(file_name)
  6.  
  7. # # 当我们获取了文件对象以后,所有的对文件的操作都应该通过对象来进行
  8. # # 读取文件中的内容
  9. # # read()方法,用来读取文件中的内容,它会将内容全部保存为一个字符串返回
  10. # content = file_obj.read()
  11.  
  12. # print(content)
  13.  
  14. # # 关闭文件
  15. # # 调用close()方法来关闭文件
  16. # file_obj.close()
  17.  
  18. # with ... as 语句
  19. # with open(file_name) as file_obj :
  20. # # 在with语句中可以直接使用file_obj来做文件操作
  21. # # 此时这个文件只能在with中使用,一旦with结束则文件会自动close()
  22. # print(file_obj.read())
  23.  
  24. file_name = 'hello'
  25.  
  26. try:
  27. with open(file_name) as file_obj :
  28. print(file_obj.read())
  29. except FileNotFoundError:
  30. print(f'{file_name} 文件不存在~~')

二、读取、写入文件

  1. file_name = 'demo2.txt'
  2.  
  3. try:
  4. # 调用open()来打开一个文件,可以将文件分成两种类型
  5. # 一种,是纯文本文件(使用utf-8等编码编写的文本文件)
  6. # 一种,是二进制文件(图片、mp3、ppt等这些文件)
  7. # open()打开文件时,默认是以文本文件的形式打开的,但是open()默认的编码为None
  8. # 所以处理文本文件时,必须要指定文件的编码
  9. with open(file_name,encoding='utf-8') as file_obj:
  10. # 通过 read() 来读取文件中的内容
  11. # 如果直接调用read()它会将文本文件的所有内容全部都读取出来
  12. # 如果要读取的文件较大的话,会一次性将文件的内容加载到内存中,容易导致内存泄漏
  13. # 所以对于较大的文件,不要直接调用read()
  14. # help(file_obj.read)
  15. # read()可以接收一个size作为参数,该参数用来指定要读取的字符的数量
  16. # 默认值为-1,它会读取文件中的所有字符
  17. # 可以为size指定一个值,这样read()会读取指定数量的字符,
  18. # 每一次读取都是从上次读取到位置开始读取的
  19. # 如果字符的数量小于size,则会读取剩余所有的
  20. # 如果已经读取到了文件的最后了,则会返回''空串
  21. # content = file_obj.read(-1)
  22. content = file_obj.read(6)
  23. content = file_obj.read(6)
  24. content = file_obj.read(6)
  25. content = file_obj.read(6)
  26. # print(content)
  27. # print(len(content))
  28. except FileNotFoundError :
  29. print(f'{file_name} 这个文件不存在!')
  30.  
  31. # 读取大文件的方式
  32. file_name = 'demo.txt'
  33.  
  34. try:
  35. with open(file_name,encoding='utf-8') as file_obj:
  36. # 定义一个变量,来保存文件的内容
  37. file_content = ''
  38. # 定义一个变量,来指定每次读取的大小
  39. chunk = 100
  40. # 创建一个循环来读取文件内容
  41. while True:
  42. # 读取chunk大小的内容
  43. content = file_obj.read(chunk)
  44.  
  45. # 检查是否读取到了内容
  46. if not content:
  47. # 内容读取完毕,退出循环
  48. break
  49.  
  50. # 输出内容
  51. # print(content,end='')
  52. file_content += content
  53.  
  54. except FileNotFoundError :
  55. print(f'{file_name} 这个文件不存在!')
  56.  
  57. print(file_content)

readline

  1. import pprint
  2. import os
  3. file_name = 'demo.txt'
  4.  
  5. with open(file_name , encoding='utf-8') as file_obj:
  6. # readline()
  7. # 该方法可以用来读取一行内容
  8. # print(file_obj.readline(),end='')
  9. # print(file_obj.readline())
  10. # print(file_obj.readline())
  11.  
  12. # readlines()
  13. # 该方法用于一行一行的读取内容,它会一次性将读取到的内容封装到一个列表中返回
  14. # r = file_obj.readlines()
  15. # pprint.pprint(r[0])
  16. # pprint.pprint(r[1])
  17. # pprint.pprint(r[2])
  18.  
  19. for t in file_obj:
  20. print(t)

写入

  1. file_name = 'demo5.txt'
  2.  
  3. # 使用open()打开文件时必须要指定打开文件所要做的操作(读、写、追加)
  4. # 如果不指定操作类型,则默认是 读取文件 , 而读取文件时是不能向文件中写入的
  5. # r 表示只读的
  6. # w 表示是可写的,使用w来写入文件时,如果文件不存在会创建文件,如果文件存在则会截断文件
  7. # 截断文件指删除原来文件中的所有内容
  8. # a 表示追加内容,如果文件不存在会创建文件,如果文件存在则会向文件中追加内容
  9. # x 用来新建文件,如果文件不存在则创建,存在则报错
  10. # + 为操作符增加功能
  11. # r+ 即可读又可写,文件不存在会报错
  12. # w+
  13. # a+
  14. # with open(file_name , 'w' , encoding='utf-8') as file_obj:
  15. # with open(file_name , 'r+' , encoding='utf-8') as file_obj:
  16. with open(file_name , 'x' , encoding='utf-8') as file_obj:
  17. # write()来向文件中写入内容,
  18. # 如果操作的是一个文本文件的话,则write()需要传递一个字符串作为参数
  19. # 该方法会可以分多次向文件中写入内容
  20. # 写入完成以后,该方法会返回写入的字符的个数
  21. file_obj.write('aaa\n')
  22. file_obj.write('bbb\n')
  23. file_obj.write('ccc\n')
  24. r = file_obj.write(str(123)+'123123\n')
  25. r = file_obj.write('今天天气真不错')
  26. print(r)

二进制

  1. file_name = 'c:/Users/lilichao/Desktop/告白气球.flac'
  2.  
  3. # 读取模式
  4. # t 读取文本文件(默认值)
  5. # b 读取二进制文件(除了txt文件之外的文件)
  6.  
  7. with open(file_name , 'rb') as file_obj:
  8. # 读取文本文件时,size是以字符为单位的
  9. # 读取二进制文件时,size是以字节为单位
  10. # print(file_obj.read(100))
  11.  
  12. # 将读取到的内容写出来
  13. # 定义一个新的文件
  14. new_name = 'aa.flac'
  15.  
  16. with open(new_name , 'wb') as new_obj:
  17.  
  18. # 定义每次读取的大小
  19. chunk = 1024 * 100
  20.  
  21. while True :
  22. # 从已有的对象中读取数据
  23. content = file_obj.read(chunk)
  24.  
  25. # 内容读取完毕,终止循环
  26. if not content :
  27. break
  28.  
  29. # 将读取到的数据写入到新对象中
  30. new_obj.write(content)

seek()设置读取文件的位置

  1. # with open('demo.txt','rb') as file_obj:
  2. # # print(file_obj.read(100))
  3. # # print(file_obj.read(30))
  4.  
  5. # # seek() 可以修改当前读取的位置
  6. # file_obj.seek(55)
  7. # file_obj.seek(80,0)
  8. # file_obj.seek(70,1)
  9. # file_obj.seek(-10,2)
  10. # # seek()需要两个参数
  11. # # 第一个 是要切换到的位置
  12. # # 第二个 计算位置方式
  13. # # 可选值:
  14. # # 0 从头计算,默认值
  15. # # 1 从当前位置计算
  16. # # 2 从最后位置开始计算
  17.  
  18. # print(file_obj.read())
  19.  
  20. # # tell() 方法用来查看当前读取的位置
  21. # print('当前读取到了 -->',file_obj.tell())
  22.  
  23. with open('demo2.txt','rt' , encoding='utf-8') as file_obj:
  24. # print(file_obj.read(100))
  25. # print(file_obj.read(30))
  26.  
  27. # seek() 可以修改当前读取的位置
  28. file_obj.seek(9)
  29. # seek()需要两个参数
  30. # 第一个 是要切换到的位置
  31. # 第二个 计算位置方式
  32. # 可选值:
  33. # 0 从头计算,默认值
  34. # 1 从当前位置计算
  35. # 2 从最后位置开始计算
  36.  
  37. print(file_obj.read())
  38.  
  39. # tell() 方法用来查看当前读取的位置
  40. print('当前读取到了 -->',file_obj.tell())

其他操作

  1. import os
  2. from pprint import pprint
  3.  
  4. # os.listdir() 获取指定目录的目录结构
  5. # 需要一个路径作为参数,会获取到该路径下的目录结构,默认路径为 . 当前目录
  6. # 该方法会返回一个列表,目录中的每一个文件(夹)的名字都是列表中的一个元素
  7. r = os.listdir()
  8.  
  9. # os.getcwd() 获取当前所在的目录
  10. r = os.getcwd()
  11.  
  12. # os.chdir() 切换当前所在的目录 作用相当于 cd
  13. # os.chdir('c:/')
  14.  
  15. # r = os.getcwd()
  16.  
  17. # 创建目录
  18. # os.mkdir("aaa") # 在当前目录下创建一个名字为 aaa 的目录
  19.  
  20. # 删除目录
  21. # os.rmdir('abc')
  22.  
  23. # open('aa.txt','w')
  24. # 删除文件
  25. # os.remove('aa.txt')
  26.  
  27. # os.rename('旧名字','新名字') 可以对一个文件进行重命名,也可以用来移动一个文件
  28. # os.rename('aa.txt','bb.txt')
  29. os.rename('bb.txt','c:/users/lilichao/desktop/bb.txt')
  30.  
  31. pprint(r)

[19/10/16-星期四] Python中的文件操作的更多相关文章

  1. 关于Python中的文件操作(转)

    总是记不住API.昨晚写的时候用到了这些,但是没记住,于是就索性整理一下吧: python中对文件.文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块. 得到当前工作目录,即当前Pyth ...

  2. python学习之【第十一篇】:Python中的文件操作

    1.前言 在Python中,对文件的操作主要遵循以下流程: 打开文件,得到文件句柄并赋值给一个变量 通过文件句柄对文件进行操作 关闭文件 2.打开文件 使用open函数,可以打开一个已经存在的文件,或 ...

  3. 【Python】解析Python中的文件操作

    目录结构: contents structure [-] 简介 Python中的文件类型 内置函数的文件操作 open()函数 Mode 创建文本文件 读取文本文件 循环文件对象 关闭文件 With语 ...

  4. [19/10/13-星期日] Python中的函数

    一.函数 # 第五章 函数 ## 函数简介(function) - 函数也是一个对象 - 对象是内存中专门用来存储数据的一块区域 - 函数可以用来保存一些可执行的代码,并且可以在需要时,对这些语句进行 ...

  5. 说说Python 中的文件操作 和 目录操作

    我们知道,文件名.目录名和链接名都是用一个字符串作为其标识符的,但是给我们一个标识符,我们该如何确定它所指的到底是常规文件文件名.目录名还是链接名呢?这时,我们可以使用os.path模块提供的isfi ...

  6. 2018.8.6 Python中的文件操作

    前言: 使用python来读写文件是非常简单的操作,我们使用open()函数来打开一个文件,获取到文件句柄.然后通过文件句柄就可以进行各种操作了,根据打开方式的不同能够执行的操作也会有相应的差异. 打 ...

  7. Python 中关于文件操作的注意事项

    文件操作 #打开文件 f = open('要打开的文件路径',mode = 'r/w/a', encoding = '文件原来写入时的编码') #操作 data = f.read() #读取 f.wr ...

  8. python中的文件操作

    文件操作时,有'r','w','a'不同的操作类型,其中'r'只能读文件,seek(),tell()函数定位读的起始地方.'w'会清空文件内容然后写文件,seek(),tell()函数定位写的起始地方 ...

  9. python中的文件操作小结1

    #!/usr/local/bin/python3 # -*- coding:utf-8 -*- f=open("test_1",'r',encoding="utf-8&q ...

随机推荐

  1. N皇后问题的递归与非递归解法

    都在注释里了: public class NQueen { public static void main(String[] args) { Scanner sc = new Scanner(Syst ...

  2. Vue路由参数设置可有可无

    参数后面使用 ? id 后面加个 ‘ ? ’ ,将 id 设置为可选参数 { name: "index", path: '/p/:id?', component: resolve ...

  3. MySQL数据表

    创建数据表 CREATE TABLE IF NOT EXISTS ([列名column][类型type][约束可选])   查看数据表结构 DESC <表名> 修改数据表结构 ALTER ...

  4. ASP设置动态表头

    /// <summary> /// 设置动态表头 /// </summary> /// <param name="sender"></pa ...

  5. 导入本地Excel到DataSet中

    /// <summary> /// 导入本地Excel到DataSet中 /// </summary> /// <param name="strFileSour ...

  6. LeetCode - LRU怎么将书架上的旧书完美淘汰呢

    你有一排书架,有空时会拿些书来看,经常性会买些新书.无奈书架容量有限,当新买的书放不下时,需要一个策略将旧书淘汰. LRU(最近最少使用)缓存淘汰机制正合适. 1)新买的书放在最左侧. 2)最近常看的 ...

  7. 使用vscode打断点

    1.vscode打开的文件必须只包含你要调适的项目,不能同时在一个vscode打开多个项目窗口 2.点击vscode的这个小蜘蛛 3.选择添加配置 4.此时自动生成了一个文件,launch.json: ...

  8. Jmeter -- 上下文关联(JSON提取器)

    目标: 将请求A响应数据的部分内容提取出来,保存成变量供后续请求使用(用在返回格式为json的HTTP请求中) 步骤: 1. 添加JSON Extractor后置处理器 add --> post ...

  9. android日志优先级

    Android 的日志分为如下几个优先级(priority): V —— Verbose(最低,输出得最多) D —— Debug I —— Info W —— Warning E —— Error ...

  10. wannalfy 挑战赛7 E 珂朵莉与GCD (离线+线段树/树状数组)

    链接:https://www.nowcoder.com/acm/contest/56/E 时间限制:C/C++ 5秒,其他语言10秒 空间限制:C/C++ 716800K,其他语言1433600K 6 ...