Python开发——6.文件操作
一、文件操作
1.文件操作的处理流程
打开文件得到文件句柄并赋值给一个变量====》通过句柄对文件进行分析====》关闭文件
#1. 打开文件,得到文件句柄并赋值给一个变量
f=open('Lakers.txt','r',encoding='utf-8') #默认打开模式就为r #2. 通过句柄对文件进行操作
data=f.read() #3. 关闭文件
f.close()
为了避免忘记关闭文件,可以用with open
#读
with open("Lakers.txt", "r", encoding="utf-8") as f:
data = f.read()
print(data)
#写
with open("Lakers.txt","r",encoding="utf-8") as f1, \
open("Spurs.txt","w",encoding="utf-8") as f2:
data1 = f1.read()
f2.write("tim\n21\n未来是你的")
print(data1)
文件打开时指定的编码要和保存时指定的编码相同,否则会出现乱码。
2.打开文件的模式
(1)打开文件的模式
打开文件的模式(默认为文本模式):只读(r),只写(w),只追加(a)
(2)非文本模式
对于非文本模式,只能用b模式,“b”表示以字节的方式操作,rb,wb,ab。b模式不需要考虑文本文件的字符编码、图片、视频的格式等,读取的内容是字节类型,写入时也要指定字节类型,不能指定编码。
a.文件模式
r 读模式,默认的模式
f = open("Lakers.txt","r",encoding="utf-8")
data = f.read()
print(data)
w 写模式,写之前会创建新的文件,如果文件存在,内容会被覆盖
f = open("Lakers.txt","w",encoding="utf-8")
f.write("kobe byrant\n24&8\n湖人总冠军")
f.close()
a 写模式,在文件最后追加内容
f = open("Lakers.txt","a",encoding="utf-8")
f.write("老子库兹马,又帅又能打")
f.close()
b.binary mod,二进制模式
b的方式读
f = open("Lakers.txt","rb")
data = f.read()
print(data)
print(data.decode("utf-8"))
f.close()
b的方式写
f = open("Spurs.txt","wb")
f.write(bytes("马刺马刺马刺\nTim Duncon\n未来是你的",encoding="utf-8"))
f.close()
c.t text mod,文本模式
d.+ open a disk file for updating (reading and writing)
e.U universal newline mode (for backwards compatibility; should not be used in new code)\r\n
f = open("Spurs.txt","r",encoding="utf-8",newline="")
data = f.readlines()
print(data
3.文件的操作
(1)f.read()
读取文件的全部内容,光标移动到文件的末尾
(2)f.readline()
读取文件的一行内容,光标移动到文件下一行开头
with open("Lakers.txt","r",encoding="utf-8") as f:
data1 = f.readline()
data2 = f.readline()
data3 = f.readline()
data4 = f.readline()
# data5 = f.readline()
print(data1,data2,data3,data4)
(3)f.readlines()
读取每一行内容,存放于列表中
with open("Lakers.txt","r",encoding="utf-8") as f:
data1 = f.readlines()
print(data1)
(4)f.write()
(5)f.writelines()
with open("Spurs.txt","a",encoding="utf-8") as f:
f.writelines(["\nkawaii\n","张铁林\n","张继科\n"])
(6)
f.readable() 判断文件是否可读
f.writable() 判断文件是否可写??
f.closed() 判断文件是否关闭
f.flush() 将文件从内存刷新到硬盘
4.光标移动
f.read(n) 文本模式下移动n个字符,b模式下移动n个字节
f.seek(n) 任何模式下都是移动n个字节
offset -- 开始的偏移量,也就是代表需要移动偏移的字节数
whence:可选,默认值为 0。给offset参数一个定义,表示要从哪个位置开始偏移;0代表从文件开头开始算起,1代表从当前位置开始算起,2代表从文件末尾算起。1和2必须在b模式下
f = open("Lakers.txt","rb")
f.seek(3,0)
print(f.tell())
f.seek(3,1)
print(f.tell())
f.seek(-3,2)
print(f.tell())
f.truncate(n) 截取n个字节
f.tell() 显示光标当前位置
二、一个文件操作系统
# 实现功能:1.函数操作 2.文件处理 3.tag的用法 4.文件的解耦
import os
def file_handler(backend_data,res=None,type="fetch"):#文件的解耦
if type == "fetch":
with open("haproxy.conf","r") as read_f:
tag = False#tag用法
ret= []
for read_line in read_f:
if read_line.strip()==backend_data:
tag =True
continue
if tag and read_line.startswith("backend"):
break
if tag:
print(read_line,end="")
ret.append(read_line)
return ret
elif type == "change":
with open("haproxy.conf", "r") as read_f, open("haproxy.conf_new", "w") as write_f:
tag = False
has_write = False
for read_line in read_f:
if read_line.strip() == backend_data:
tag = True
continue
if tag and read_line.startswith("backend"):
tag = False
if not tag:
write_f.write(read_line)
else:
if not has_write:
for record in res:
write_f.write(record)
has_write = True
os.rename("haproxy.conf", "haproxy.conf.bak")
os.rename("haproxy.conf_new", "haproxy.conf")
os.remove("haproxy.conf.bak")
def fetch(data):
print("这是查询功能")
print("用户数据是",data)
backend_dat= "backend %s" %data
return (file_handler(backend_dat)) def add():
pass def change(data):
backend=data[0]["backend"]
backend_data="backend %s" %backend
old_server_record="%sserver %s %s weight %s maxconn %s\n" %(" "*8,data[0]["record"]["server"],
data[0]["record"]["server"],
data[0]["record"]["weight"],
data[0]["record"]["maxconn"])
new_server_record="%sserver %s %s weight %s maxconn %s\n" %(" "*8,data[1]["record"]["server"],
data[1]["record"]["server"],
data[1]["record"]["weight"],
data[1]["record"]["maxconn"])
print("用户想要修改的记录是:",old_server_record)
res = fetch(backend)
print("来自change函数读取的内容:",res)
if not res or old_server_record not in res:
print("没有找到要修改的内容")
else:
index = res.index(old_server_record)
res[index]=new_server_record
res.insert(0,"%s\n" %backend_data)
file_handler(backend_data,res=res,type="change")
return res def delete():
pass if __name__ == "__main__":#判断功能
msg='''
1:查询
2:增加
3:修改
4:删除
5:退出
'''
msg_dic={
"":fetch,
"":add,
"":change,
"":delete,
}
while True:
print(msg)
choice = input("请输入你的选项: ").strip()
if not choice:continue
if choice == "": break data = input("请输入你的数据:").strip()
if choice != "":
data = eval(data) res = msg_dic[choice](data)
print(res)
# [{"backend":"www.oldboy1.org","record":{"server":"2.2.2.4","weight":"20","maxconn":"3000"}},{"backend":"www.oldboy1.org","record":{"server":"2.2.2.5","weight":"20","maxconn":"3000"}}]
文件操作系统
Python开发——6.文件操作的更多相关文章
- python开发_python文件操作
关于python文件操作的详细说明,大家可以参考:关于python的文件操作 官方API:os-Miscellaneous operating system interfaces 下面是我做的demo ...
- 05 python开发之文件处理
05 python开发之文件处理 目录 05 python开发之文件处理 5 文件处理 5.1 字符编码 5.1.1 基本概念 5.1.2 发展历程 5.1.3 使用 5.2 文件处理基础 5.2.1 ...
- python os&shutil 文件操作
python os&shutil 文件操作 # os 模块 os.sep 可以取代操作系统特定的路径分隔符.windows下为 '\\' os.name 字符串指示你正在使用的平台.比如对于W ...
- python 历险记(三)— python 的常用文件操作
目录 前言 文件 什么是文件? 如何在 python 中打开文件? python 文件对象有哪些属性? 如何读文件? read() readline() 如何写文件? 如何操作文件和目录? 强大的 o ...
- Python的高级文件操作(shutil模块)
Python的高级文件操作(shutil模块) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 如果让我们用python的文件处理来进行文件拷贝,想必很多小伙伴的思路是:使用打开2个 ...
- Python入门篇-文件操作
Python入门篇-文件操作 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.文件IO常用操作 open:打开 read:读取 write:写入 close:关闭 readlin ...
- python基础篇(文件操作)
Python基础篇(文件操作) 一.初始文件操作 使用python来读写文件是非常简单的操作. 我们使用open()函数来打开一个文件, 获取到文件句柄. 然后通过文件句柄就可以进行各种各样的操作了. ...
- Python之常用文件操作
Python之常用文件操作
- Python开发【第三篇】:Python基本之文件操作
Python基本之文本操作 一.初识文本的基本操作 在python中打开文件有两种方式,即:open(...) 和 file(...) ,本质上前者在内部会调用后者来进行文件操作,推荐使用 open ...
随机推荐
- 换上 SansForgetica-Regular 字体,增加记忆能力
最近澳大利亚的RMIT(皇家墨尔本理工大学) 搞出来这么个字体,号称能增强记忆,原理是通过难以识别的字体,让人提起精神去识别,从而记忆更深刻. 果断弄了个试试. 安装过程: 下载字体文件 点这里去下载 ...
- how find out what is causing Visual Studio to think each project is out of date
You can find out what is causing Visual Studio to think each project is out of date, and then addres ...
- 什么是Java序列化,如何实现java序列化
简要解释: 序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化.可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间. 序列化是为了解决在对对象流进行读写操作时所 ...
- 59.纯 CSS 创作彩虹背景文字
原文地址:https://segmentfault.com/a/1190000015352436 修改后地址:https://scrimba.com/c/cqK3LaTQ 感想: 又一次见识到CSS的 ...
- org.apache.ibatis.builder.IncompleteElementException: Could not find result map java.util.HashMap
这样的配置有问题吗? <select id="getFreightCollectManagementList" resultMap="java.util.HashM ...
- ubuntu 从零安装tf-serving环境和opencv
参考官网:https://www.tensorflow.org/serving/setup 首先是安装gprc: pip install grpcio 然后发现没有安装pip,报错:sudo: pip ...
- EL表达式与标签库
https://blog.csdn.net/panhaigang123/article/details/78428567
- 交叉编译bash
1 下载bash版本:[version 4.2.53]地址:http://ftp.gnu.org/gnu/bash/ 2 解压将下载的bash压缩包解压,命令: # mkdir /home/carri ...
- eclipse中启动项目报内存溢出问题通过修改配置解决
标注:添加下面的参数还是挺管用的,本人亲测可试,同时启用两个项目,总是报堆内存不足,加了下面的参数后变可以同时正常运行了. 错误如下: Error occurred during initializ ...
- centos查看系统版本
显示系统版本 cat /etc/redhat-release cat /proc/version uname -a 查看位数 file /bin/ls