文件的各种操作

文件操作

f = open('文件的路径',mode = '打开文件的模式',encoding = '编码方式')
# 打开 第一个内容是文件的名字(必须是字符串)
# mode 第二个内容是我们对文件的操作方式
# encoding 第三个内容是我们文件的编码集
# f 文件句柄所有对文件的操作都是操作文件句柄

只读

mode = 'r'

# mode = 'r' 只读
content = f.read()  # 读 一次性全部读取
content = f.readline()  # 读取一行,但是一行后有\n换行
content = f.readlines()  # 读取多行,存放在列表里
content = f.read(3) # mode = 'r' read里的内容就是表示读取的字符数量
print(content)

mode = 'rb'

f = open(r'c:\Users\Super La\Desktop\qwe.txt', mode = 'rb')
# r 和 \\ 一样都是转义  r'c:\Users\Super La\Desktop\qwe.txt'      'c:\\Users\\Super La\\Desktop\\qwe.txt'
# 如果直接拷贝文件路径的话 将C转换成c
# rb读取字节
print(f.read()) # 读取字节 不能指定编码格式

绝对路径:从磁盘开始查找的就是绝对路径

相对路径:相对与 上文件夹内容详解来查找的一种路径

文件路径推荐写法 用相对路径

只写

mode = 'w'

f = open('t1.txt', mode = 'w', encoding = 'utf8')
f.write('lalalalaalal')
f.write('啦啦啦啦啦啦')
print(f.write('123456'))  # 返回创建字符的数量
# w模式 如果文件不存在就新建一个
# 覆盖写,写之前先把文件清空

mode = 'wb'

f = open('qq.jpg',mode = 'rb')
f = open('qq1.jpg',mode = 'wb')
f.write(f.read())

a 模式 追加

f = open('t1',mode = 'a', encoding = 'utf8')
f.write('lalala')
#文件最后添加内容

'w' 只写 没有读的功能 打开word 打不开

读写

r+ 读 写

f = open('t1',mode = 'r+',encoding = 'utf8')
# 读 写
#print(f.read())  #读内容
#f.write('啦啦啦') 

# 写 读 错误示范 写的时候会把源文件覆盖一部分
#f.write('啦啦啦') 
#print(f.read())  #读内容

w+ 写 读

f = open('t1',mode = 'w+',encoding = 'utf8')
f.write('lalala')
f.seek(0)  # 移动文件光标 
print(f.read())

a+ 追加 读

f = open('t1',mode = 'a+',encoding = 'utf8')
f.seek(0)
print(f.read())
f.write('哈哈哈')

最常用的r+

f = open(r'..\t1',mode = 'r+',encoding = 'utf8')
# ..\ 返回上一级
#print(f.read())  # 读内容
#f.write('今天是个好日子')

总结:

# r 只读    不能写
# read()    读取全部  模式是r的时候  read(3)  读取3个字符
# 				    模式是rb的时候  read(3)  读取3个字节
# read()         读取一行
# readlines()    存放在一个列表中

# w 只写    不能读   覆盖写,先清空文件的内容,再写
# 当文件不存在的时候,创建一个文件

# a 追加 不能读
# 写的内容一直在问价的末尾

# r+
# 错误示范    先写在读
# 正确的是    先读在写

# w+    写读
# 写读的时候是读不到内容的,除非移动光标

# a+  追加写  读
# 写读的时候是读不到内容的,除非移动光标
# 最常用:r, w, a, r+, a+

f = open('t1',mode = 'r',encoding = 'utf8')
print(f.read())
msg = f.read()
print(msg)
f.close()  # 关闭文件

f = open('t1',mode = 'w',encoding = 'utf8')
msg = f.write('啦啦啦')
f.flush()   # 刷新
print(msg)
f.close()

with open('t1', mode = 'r', encoding = 'utf8') as f : # 上下文管理    ---面试题
    msg = f.read()
    print(msg)
# 不用自动关闭

文件其他操作

with open('t1','r',encoding = 'utf8') as f:
    print(f.read())
    print(f.seeek(0)) # 字节
    # 双数字
   		 # (0,0)文件的头部
  		 # (0,2)文件的尾部
   		 # (0,1)当前位置
     # 单数字
   		 seek(0)	# 字节  
    print(f.read(1)) # 读一个字符
    print(f.tell()) # 查看光标的位置  数的字节

with open('t1','r',encoding = 'utf8') as f:
    f.truncate(9)	# 截取 3个字符 指定字节之后的内容全部删除
    

文件更改及名字修改

import os
os.rename('t2','t3') # 修改文件名

with open('t1','r',encoding = 'utf8') as f , open('t2','a',encoding = 'utf8') as f1:
    msg = f.read()   # 将文件复制一份
    msg = msg.replace('好','困')
    f1.write(msg)
    
import os
os.remove('t1')  # 删除源数据
os.rename('t2','t3')

with open('t4',mode = 'r',encoding = 'utf8') as f, open('t6', mode = 'a',encoding = 'utf8') as f2:
    for i in f:
        print(i.strip())
    	f2.write(i) # 文件修改

今日总结:

	# open()  # 打开
	# close	要关闭文件
	# 写模式下需要刷新  flush()

	# r 只读
	# 	read(3)   看对文件操作的模式来判断是字符还是字节
	# 	mode = 'r' 时候是字符
	# 	mode = 'rb' 时候是字节
	# readline()   读取一行,自带\n(换行)
	# readlines()  读取全部以一行一行的形式存在放列表里

	# a 追加
		#文件的末尾写
	# w 覆盖写
		# 先清空文件,后写入文件

	# rb ,wb ab自己试
		# 只要是带b的模式,注意的是不是不能有encoding

	# a+
	#   追加 + 读     注意 不管怎么读都读不到内容,除非移动光标

	# w+
	# 	覆盖写 + 读   注意:先写后读  先读后写   除非移动光标

	# r+
	# 	读 + 写      注意: 先读后写

	# 其他操作

	# seek()  移动光标
	#  	0,0    开头
	# 	0,1    当前
	# 	0,2    末尾

	# 3 如果是文字就移动一位,如果是英文就移动3位

	# tell() 查看光标 光标是按照字节数的

	# truncate()  截取  内容是字节数

# 文件修改
import os  # 导入  os和操作系统相关

# os.rename()  # 重命名  第一个参数旧的名字,第二个是新的名字
# os.remove()    # 删除这个文件  字符串


# with open('t1','r',encoding='utf-8')as f,\
# 		open('t2','w',encoding='utf-8')as f1:

# 路径:

# 绝对路劲: 从磁盘根目录开始查找
# 相对路劲: 相对于某个东西来查找就是相对路径
# 	返回上一级 ..\
# c:\user\...    可以把单个\写成双\\
# 在路径的前面加一个r
# 以上两种就是转义

posted @ 2019-07-15 15:41  626  阅读(225)  评论(0编辑  收藏  举报