day13 基本的文件操作(好东西)
基本的文件处理
什么是文件
- 文件是操作系统提供的虚拟的单位,有了文件我们可以读取数据,没有文件的话应该去硬盘上扣动机械手臂然后寻找数据.
如何使用文件
- 打开文件()
- 读写数据
- 保存
- 关闭文件
使用Python写一个小程序控制文件
open(打开文件)
- 格式:open('文件名', mode='模式', encoding='编码格式')
- 模式默认为r,编码格式默认为读取软件的编码格式
- 如果在txt中写编码格式则为gbk,在Pycharm或者Python中写则为utf-8, word编码格式不是gbk也不是utf-8,不懂可以参考上一篇文章
fr = open('test1.txt', mode='r', encoding='utf-8')
read:
默认一次性全部读取,里面的参数可以设置从第几个字符开始看,按字符算,其他都是按字节算
读取完了后,再进行读取,则为空
data = fr.read() # 用data去接收返回值,也就是文本的内容
print(data) # 输出文本内容
readline:一次性读取一行
- 一次性读取一行,会读取\n
- 如果读完所有数据,继续读取为空
print(fr.readline())
del:删除
- 只是删除了变量名,但是文件对于操作系统来讲,还是打开状态的
del fr
close:关闭
- 不仅删除了变量名fr,而且也关闭了文件,这个时候文件对于操作系统来说是关闭状态的
fr.close()
- 打开文件时操作的是硬盘和内存
- 而Python3只是软件,无法操控硬件,所以也是由操作系统在进行交互
- 所以当你用del删除变量名时,只是删除了变量名的内存占用,并没有让操作系统关闭文件
write(写入)
- 会清空当前文件的内容,再写
fw = open('test1.txt', mode='w', encoding='utf-8')
fw.write('12345')
flush 快速刷入硬盘
提高写入优先级,写完write习惯性加一个flush
绝对路径
- 文件在电脑上的路径
fr = opne('C:\Users\Y\Desktop\123.txt', mode = 'r', encoding = 'utf-8')
相对路径
文件相对于工作文件夹的路径
注意打开的文件夹和运行的py文件需要是同文件夹下的,不然需要修改相对路径的一些信息
文件的三种打开方式
mode = 'r' , 只读, 默认模式
fr = open('test.txt', mode = 'r', encoding = 'utf-8') # 默认r,和rt相同
mode = 'w' , 只写,会清空之前的内容
fw = open('test.txt', mode = 'w', encoding = 'utf-8')
mode = 'a' , 追加,在后面追加写入文件
fa = open('test.txt', mode = 'a', encoding = 'utf-8')
mode = 'rt' , 打开的text文本类型
- 和r相同
fr = open('test.txt', mode = 'rt', encoding = 'utf-8')
mode = 'rb' ,打开的bytes类型,(二进制)
- 没有encoding,因为本身就是二进制不需要编码
frb = open('test.txt', mode = 'rb')
'wt', 'at'和'w', 'a'相同,而'wb', 'ab'用不上,你不会写二进制
在字符串前面加r,告诉接下来的字符串,里面所有特殊字符(如\)都毫无意义
在字符串前面加b,是告诉print字符串里面是二进制数,不要再用终端的编码进行编译了,原生打印就可以了
with open()
- 比open()好用,会自动关闭,不需要写close
- 里面的写法和open一样,只是变量名用as写到后面,下面的内容要缩进
with open('test.txt', mode='r', encoding='utf-8') as 变量名:
文件高级应用
r+:可读可写,会替换写
w+:可读可写,但是会清空写)
a+:可读可写,追加写
以上三种方式不推荐使用,可以先读再写,没必要同时
指针
- 需要有一个文件,并且打开,指针就是光标所处的位置
- 不推荐使用
with open('test.txt', mode='r+', encoding='utf-8') as fr:
fr.seek(3) # 三个字节
fr.write('123')
fr.flush()
原文件: 999999
修改后:999123
文件的写没有插入一说,只有替换,覆盖
而电脑word或者txt文本中的可以直接插入其实是
一个中文是3个字节,一个英文是1个字节,一般都是字节,只有read中是字符
seek(a,b)
a是指针移动的字节数
b如果是0是文件开头,1是指针当前位置,2是末尾,但如果要1或者2,那么只能使用2进制
tell
- 告诉光标当前的位置
read
- read中有一个参数,是光标移动的字符个数,只有这次用的是字符
truncate
- 清空文本,如果有参数,则光标会跳到指定字节数后,然后把后面的文件全部清空,无视之前用seek移动的光标位置
文件的拷贝
- 修改文件时,为了防止两个应用程序同事修改同一份文件,而导致报错,因为你书写是一个修改的过程,而当第一个程序修改了一个字符后,如果第二个程序也要修改这个字符,那么就会报错
- 为了避免这种情况,会在修改时新建一个拷贝文件,然后都在拷贝文件中进行修改,最后删掉原有的,把拷贝后的文件改名放进去
文件修改的过程(示例)
# 把文件读出来,替换内容
with open('test.txt', mode='r', encoding='utf-8') as fr:
data = fr.read()
data = data.replace('a', 'b')
# 另外用一个文件,写入替换后的内容
with open('test_swap.txt', mode='w', encoding='utf-8') as fw:
fw.write(data)
# 用os模块删除test文件,再把test_swap文件改名成test
import os
os.remove('test.txt')
os.rename('test_swap.txt', 'test.txt')
# 简便版
# 把文件读出来,替换内容,再写入一个文件中
with open('test.txt', mode='r', encoding='utf-8') as fr,\
open('test_swap.txt', mode='w', encoding='utf-8') as fw:
data = fr.read()
data = data.replace('a', 'b')
fw.write(data)
# 用os模块删除test文件,再把test_swap文件改名成test
import os
os.remove('test.txt')
os.rename('test_swap.txt', 'test.txt')
修改文件内容的两种方式
- 第一种,上面写的,把文件全部读出来,然后一起替换
- 第二种,下面写的,对文件进行逐行修改,节省内存空间(推荐)
import os
with open('test.txt', mode='r', encoding='utf-8') as fr,\
open('test_swap.txt', mode='w', encoding='utf-8'):
# 循环读取内容,逐行修改
for line in fr: # 和for line in fr.read():效果一样
line = line.replace('a', 'b')
# 新文件写入原文件修改后的内容,之所以不会每次写入都清空之前的数据,是因为清空这个过程并不是write造成的,而是在open文件时,mode='w'造成的.所以循环写入不会有影响
fw.write(line)
enumerate
会在原有的值前面加一个下标值,用k,v 去接受,类似于items
day13 基本的文件操作(好东西)的更多相关文章
- 【.NET深呼吸】Zip文件操作(1):创建和读取zip文档
.net的IO操作支持对zip文件的创建.读写和更新.使用起来也比较简单,.net的一向作风,东西都准备好了,至于如何使用,请看着办. 要对zip文件进行操作,主要用到以下三个类: 1.ZipFile ...
- python 文件操作(转)
python中对文件.文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块. 得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd() 返回指定目录下的所有文件和目 ...
- python文件操作
总是记不住API.昨晚写的时候用到了这些,但是没记住,于是就索性整理一下吧: python中对文件.文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块. 得到当前工作目录,即当前Pyth ...
- python学习道路(day3note)(元组,字典 ,集合,字符编码,文件操作)
1.元组()元组跟列表一样,但是不能增删改,能查.元组又叫只读列表2个方法 一个 count 一个 index2.字典{}字典是通过key来寻找value因为这里功能比较多,所以写入了一个Code里面 ...
- 关于Python中的文件操作(转)
总是记不住API.昨晚写的时候用到了这些,但是没记住,于是就索性整理一下吧: python中对文件.文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块. 得到当前工作目录,即当前Pyth ...
- C的文件操作2
[转] C语言文件操作 概述 所谓文件(file)一般指存储在外部介质上数据的集合,比如我们经常使用的mp3.mp4.txt.bmp.jpg.exe.rmvb等等.这些文件各有各的用途,我们通常将它 ...
- python学习笔记4(文件操作)
文件操作: 1.f=open(”caidan”,”w”,encoding=”utf8”) 直接打开一个文件,如果文件不存在则创建文件 f.close() 2.with open (”caid ...
- C语言文件操作
C语言文件操作,以下以基本的例子和说明来展开怎么通过C语言来进行文件操作. 操作文件,我们得需要知道什么?当然是路径和文件名. 首先我需要知道我操作的文件在哪里,叫什么名字.在C语言中还存在一个打开方 ...
- Python开发【第三章】:Python的文件操作
一.文件操作模式概述 1.打开文件的模式: r, 只读模式[默认] w,只写模式[不可读:不存在则创建:存在则删除内容:] a, 追加模式[不可读:不存在则创建:存在则只追加内容:] 2." ...
随机推荐
- JS中的map
定义和用法: map() 方法返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值. map() 方法按照原始数组元素顺序依次处理元素. 注意: map() 不会对空数组进行检测. 注意: m ...
- Spring Boot 项目学习 (四) Spring Boot整合Swagger2自动生成API文档
0 引言 在做服务端开发的时候,难免会涉及到API 接口文档的编写,可以经历过手写API 文档的过程,就会发现,一个自动生成API文档可以提高多少的效率. 以下列举几个手写API 文档的痛点: 文档需 ...
- MySQL 单表查询多表查询
一 单表查询 表准备 create table emp( id int not null unique auto_increment, name varchar(20) not null, sex e ...
- xml01 验证
xml 验证 拥有正确的格式的xml是"形势良好"的xml 通过DTD验证的xml是"合法的"xml
- Web安全扫描工具
使用 Ibm security appscan 进行WEB安全扫描. 1.SQL注入: 2.发现内部IP泄露模式: 3.已解密的登录请求: 4.HTML注释敏感信息泄露:
- C#实现调用接口数据获取数据格式化XML、json转成Table的方法
废话不多说,直接上代码: json 格式化转DataTable: result为从接口得到的数据,格式化json的方法主要来自Newtonsoft.Json JObject joUnit = JObj ...
- 使用rsync同步数据(by quqi99)
作者:张华 发表于:2015-12-28版权声明:能够随意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本版权声明 ( http://blog.csdn.net/quqi99 ) 急需使 ...
- iOS项目开发实战——制作视图的缩放动画
视图的大小应该是随时可控的.今天我们就来实现对一个View的缩放动画.该动画的实现与位移动画,透明度动画稍有不同. 详细实现例如以下: import UIKit class ScaleViewCont ...
- linux删除多行
光标放到行dd:删除所在行 光标放到行Ndd: 删除所在行下的N行
- Oracle RAC 全局等待事件 gc current block busy 和 gc cr multi block request 说明--转载(http://blog.csdn.net/tianlesoftware/article/details/7777511)
一.RAC 全局等待事件说明 在RAC环境中,和全局调整缓存相关的最常见的等待事件是global cache cr request,global cache busy和equeue. 当一个进程访问需 ...