时间:2021-05-22
一.文件操作的流程
1、打开文件
open('C:\a.txt\nb\c\d.txt')
解决方案一:推荐
open(r'C:\a.txt\nb\c\d.txt')
解决方案二:
open('C:/a.txt/nb/c/d.txt')
f=open(r'aaa/a.txt',mode='rt') # f的值是一种变量,占用的是应用程序的内存空间
2、操作文件:
读/写文件,应用程序对文件的读写请求都是在向操作系统发送系统调用,然后由操作系统控制硬盘把输入读入内存、或者写入硬盘
res=f.read()
3、关闭文件
f.close() # 回收操作系统资源
f.read() # 变量f存在,但是不能再读了
二.资源管理与with上下文管理
打开一个文件包含两个部分资源:应用程序的变量f和操作系统打开的文件。
在操作完一个文件后必须把这两部分的资源回收
通常回收有两种方法:
1 f.close()#回收操作系统打开的文件资源
2 del f # 回收应用程序资源
其中,del f 一定要发生在f.close()之后,否则就会导致操作系统打开的文件无法关闭,。
python的垃圾回收机制让我们无序考虑del f,所以我们必须记住,操作完毕后一定要fclose(),
但是我们都是比较懒或者比较健忘的,所以python就有with关键字来帮助我们管理上下文。
1. with open('a.txt',mode='rt') as f1:# f1=open('a.txt',mode='rt')
pass
2. with open('a.txt',mode='rt') as f1,\
open('b.txt',mode='rt') as f2:
res1=f1.read()
res2=f2.read()
print(res1)
三.文件的操作模式
文件的读写操作的模式有
文件的读写内容的模式有
t 文本模式:1.读写文件都是以字符串为单位
2.只能针对文本文件
3.必须制定encoding参数
b 二进制模式:1.读写文件都是以bytes为单位的
2.可以针对所有文件
3.一定不能制定encoding参数
强调:t和b不能单独使用,必须跟r/w/a连用
各模式的参考案例
1、r(默认的操作模式):
只读模式,当文件不存在时报错,当文件存在时文件指针跳到开始位置
with open('c.txt',mode='rt',encoding='utf-8') as f: print('第一次读'.center(50,'*')) res=f.read() # 把所有内容从硬盘读入内存 print(res) with open('c.txt', mode='rt', encoding='utf-8') as f: print('第二次读'.center(50,'*')) res1=f.read() print(res1)实现用户认证功能
inp_username=input('your name>>: ').strip() inp_password=input('your password>>: ').strip() with open('user.txt',mode='rt',encoding='utf-8') as f: for line in f: # print(line,end='') # egon:123\n username,password=line.strip().split(':') #压缩赋值,取出文件中的用户名密码 if inp_username == username and inp_password == password: print('login successfull') break else: print('账号或密码错误')应用程序====》文件
应用程序====》数据库管理软件=====》文件
2、w:只写模式,当文件不存在时会创建空文件,当文件存在会清空文件,指针位于开始位置
案例:w模式用来创建全新的文件
文件文件的copy工具
就是读一个文件,再写一个文件,把读的复制给写的。
# src_file=input('源文件路径>>: ').strip()# dst_file=input('目标文件路径>>: ').strip()# with open(r'{}'.format(src_file),mode='rt',encoding='utf-8') as f1,\# open(r'{}'.format(dst_file),mode='wt',encoding='utf-8') as f2:# res=f1.read()# f2.write(res)3、a:只追加写,在文件不存在时会创建空文档,在文件存在时文件指针会直接调到末尾
强调 w 模式与 a 模式的异同:
1 相同点:在打开的文件不关闭的情况下,连续的写入,新写的内容总会跟在前写的内容之后
2 不同点:以 a 模式重新打开文件,不会清空原文件内容,会将文件指针直接移动到文件末尾,新写的内容永远写在最后
案例:a模式用来在原有的文件内存的基础之上写入新的内容,比如记录日志、注册
注册功能
name=input('your name>>: ') pwd=input('your name>>: ') with open('db.txt',mode='at',encoding='utf-8') as f: f.write('{}:{}\n'.format(name,pwd))了解:+不能单独使用,必须配合r、w、a
r+,w+,a+:可读可写
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了python解析xml文件操作的实现方法。分享给大家供大家参考。具体方法如下:xml文件内容如下:samplexmlthingmaxiaojuSp
Python文件操作的详解及实例一、文件操作1、对文件操作流程打开文件,得到文件句柄并赋值给一个变量通过句柄对文件进行操作关闭文件现有文件如下:昨夜寒蛩不住鸣。
本文实例讲述了python解析xml文件的方法。分享给大家供大家参考。具体如下:python解析xml非常方便。在diveintopython中也有讲解。如果x
有如下的xml文件:复制代码代码如下:12下面介绍python解析xml文件的几种方法,使用python模块实现。方式1,python模块实现自动遍历所有节点:
前言最近使用Python解析IDX文件格式的MNIST数据集,需要对二进制文件进行读取操作,其中我使用的是struct模块。查了网上挺多教程都写的挺好的,不过对