一、常用方法


# 写文件--开始
f=open('test','w',encoding="utf-8") #如果有则写,没有就创建
print(f.writable()) #True
f.write('11111\n');
f.writelines(['22222\n','223333\n']);
f.write('33333\n');
f.close();
# 写文件--结束 # 读取文件--开始
f=open('test',encoding="utf-8")
# data=f.read();
# print(data);
print(f.readable())
print(f.readline()) #一次读一行
print(f.readlines()) #一次所有行
f.close();
# 读取文件--结束 # 追加文件--开始 在光标处追加
f=open('test','r+',encoding="utf-8")
print(f.writable()) #True
f.write('一\n');
f.writelines(['二\n','223333\n']);
f.write('三\n');
f.close();
# 追加文件--结束 # 追加文件--开始 在光标处追加
f=open('test','a',encoding="utf-8")
print(f.writable()) #True
f.write('在结尾追加\n');
f.writelines(['在结尾追加2\n','在结尾追加3\n']);
f.close();
# 追加文件--结束
"""输出结果


223333

3333
在结尾追加
在结尾追加2
在结尾追加3
"""

文件处理1

# 文件处理b模式
#读取文件
f=open("test",'rb');# 注意,通过二进制代开文件不用指定编码
data = f.read().decode("utf-8");#但是读取的时候需要指定解码方式
print(data)
f.close()
#写入文件
f=open("test",'wb');# 注意,通过二进制代开文件不用指定编码
f.write("张三\n".encode("utf-8"))
f.close();
#追加文件
f=open("test",'ab');# 注意,通过二进制代开文件不用指定编码
f.write("李四\n".encode("utf-8"))
f.close();

通过二进制处理文件

# 读取文件最后一行
f=open("test",'rb');# 注意,通过二进制代开文件不用指定编码 for i in f:
# 设置一个偏移量,offSet、
offset=-10;
while True:
# 通过seek(偏移量,2);的方式来倒着获取光标位置
f.seek(offset,2)
# 从光标位置开始读取数据
data=f.readlines();
if len(data)>1:
print(data[-1].decode('utf-8'));
break;
offset *=2

读取文件最后一行

with open('test','r',encoding="utf-8") as  a,open('test2','w',encoding="utf-8") as b:
b.write(a.read())

复制文件

二、总结


  1:访问模式

    最基本的操作是读w、写r、追加a。

    b是表示以二进制方式读写,

    + 表示会一个查漏补缺,如果如果是r只读模式,r+就是变成读写模式    

访问模式
  w r a
b wb rb ab
+ w+ r+ a+
b+ wb+ rb+ ab+

  2:注意

    • w模式,会把原来的内容删掉,然后再写入。慎用
    • r+模式,直接写入:文件指针将会放在文件的开头。先读后写:文件指针将会放在文件的末尾。

      with open("r+有坑","w") as f:
      f.write("Hello,IO")
      ##此时文件内容为 Hello,IO # 直接使用r+的写功能
      with open("r+有坑","r+") as f:
      f.write("Hi,r+")
      ##此时文件内容为 Hi,r+,IO #结论一:打开一个文件用于读写。文件指针将会放在文件的开头。 # 先读后写
      with open("r+有坑","r+") as f:
      print(f.read(3)) #Hi,
      f.write("Hi,r+")
      ##此时文件内容为 Hi, r +, IOHi, r +
      # 结论二:如果进行了读取操作,文件指针将会放在文件的末尾

      r+的指针位置

三、练习:文件的修改


                                        古诗几首
作者:李白
题目《将进酒》
题目《早发白帝城》 作者:杜甫
题目《登高》
题目《兵车行》

古诗几首

#基本功能,实现对文件的增删改查
msg="""1:查询,2:新增
3:修改,4:删除"""
#查询功能,根据输入的作者名称,查询该作者的作品
def query(author):
print('查询作者是:\033[1;43m%s\033[0m' %author)
query_data='作者:%s'%author
query_Result=[] #记录查询结果
with open('古诗几首','r',encoding="utf-8") as read_f:
tag=False
for read_line in read_f:
if read_line.strip()==query_data:
tag = True
continue
elif read_line.strip()=="" and tag:
tag = False
break
if tag:
print(read_line,end="")
query_Result.append(read_line)
return query_Result def add():
print("这是新增功能")
def dele():
print("这是删除功能")
#这是修改功能
#格式:修改需要提供一个list集合,包含两块内容\
# data=[{'作者':'李白','内容':'题目《将进酒》'},{'作者':'李白','内容':'题目《静夜思》'}]
#修改之前,先判断文件是否存在
def modify(data):
#把拿到的data数据由字符串转换成列表
data=eval(data)
#拿到作者名称,调用Query方法,返回list集合
article_list=query(data[0]["作者"])
if not article_list :
print('输入的作者不存在')
return "输入的作者不存在"
else:
# 遍历得到的list集合,然后如果看看题目是否存在
currentArticle= " "+data[0]["内容"]+"\n"
if currentArticle not in article_list:
print('输入的作品不存在')
return '输入的作品不存在'
else:
#如果输入的作品存在
with open('古诗几首', 'r', encoding="utf-8") as read_f, \
open('古诗几首_新', 'w', encoding="utf-8") as write_f:
# 遍历文件。如果不是当前行,直接复制,如果是当前行,复制修改后的
for curLine in read_f:
if curLine.strip()!=currentArticle.strip():
write_f.write(curLine)
else:
currentArticlenew=" "+data[1]["内容"]+"\n"
write_f.write(currentArticlenew)
print("修改完成")
dic_oper={'':query,'':add,'':modify,'':dele,}
if __name__=='__main__':
while True:
print(msg)
choice=input('请输入您的选项').strip()
if not choice:continue
if choice=="":break
data=input('请输入您的数据').strip()
dic_oper[choice](data)

文件处理

饮冰三年-人工智能-Python-15Python基础之文件处理的更多相关文章

  1. 饮冰三年-人工智能-Python-21 Python数据库MySql

    一:下载与安装 1:下载地址:https://dev.mysql.com/downloads/mysql/ 2:安装MySql 打开下载文件解压到指定文件目录.(我这里解压目录为D:\MySql\my ...

  2. 饮冰三年-人工智能-Python-17Python基础之模块与包

    一.模块(modue) 简单理解一个.py文件就称之为一个模块. 1.1 模块种类: python标准库 第三方模板 应用程序自定义模块(尽量不要与内置函数重名) 1.2 模块导入方法 # impor ...

  3. 饮冰三年-人工智能-Python-10之C#与Python的对比

    1:注释 C# 中 单行注释:// 多行注释:/**/ python 中 单行注释:# 多行注释:“““内容””” 2:字符串 C#中 "" 用双引号如("我是字符串&q ...

  4. 饮冰三年-人工智能-Python-22 Python初识Django

    1:一个简单的web框架 # 导包 from wsgiref.simple_server import make_server #自定义个处理函数 def application(environ,st ...

  5. 饮冰三年-人工智能-Python-20 Python线程、进程、线程

    进程:最小的数据单元 线程:最小的执行单元 一: 1:线程1 import threading #线程 import time def Music(): print("Listen Musi ...

  6. 饮冰三年-人工智能-Python-19 Python网络编程

    Socket:套接字.作用:我们只需要安照socket的规定去编程,就不需要深入理解tcp/udp协议也可以实现 1:TCP协议 1.1  客户端服务端循环收发消息 # 1:引入stock模块(导包) ...

  7. 饮冰三年-人工智能-Python-16Python基础之迭代器、生成器、装饰器

    一:迭代器: 最大的特点:节省内存 1.1 迭代器协议 a:对象必须提供一个next方法, b:执行方法要么返回迭代中的下一项,要么抛弃一个Stopiteration异常, c:只能向后不能向前. 1 ...

  8. 饮冰三年-人工智能-Python-14Python基础之变量与函数

    1:函数:函数是逻辑结构化和过程化的一种编程方法.函数即变量 #参数组:**字典 *列表 def test(x,*args): print(args); print(args[0]); print(& ...

  9. 饮冰三年-人工智能-Python-13Python基础之运算符与数据类型

    1:算数运算符 + - * / ** % // 2: 成员运算符 in not in name = """张三""" if "张& ...

  10. 饮冰三年-人工智能-linux-08 软件包管理(Python的安装)

    1:软件包存放的位置 media/CentOS_6.9_Final/Packages文件夹下 2.RPM就是Red Hat Package Manger(红帽软件包管理工具)的缩写. 2.1 常用的命 ...

随机推荐

  1. CentOS 7安装Redis

    第一步:安装gcc依赖 先通过gcc -v是否有安装gcc,如果没有安装,执行命令 yum install -y gcc(yum install -y gcc-c++) 第二步:下载redis安装包 ...

  2. oracle坏块问题的处理

    一.背景 今天有用户反映数据库连不上了,查看日志发现有数据库坏块. 查看数据库日志,有如下报错: ORA-01578: ORACLE , 93642) ORA-01110: 1: '/oracle/a ...

  3. python,类和对象(一)

    万物皆对象,在python中也存在对象,首先我们需要知道面向对象的三大特征封装.继承.多态. 封装就是将一种或多种杂乱无序的代码进行有序的分类封装. 继承可以理解为孩子会继承父亲所有的东西. 多态可以 ...

  4. 利用jTessBoxEditor工具进行Tesseract-OCR样本训练

    jTessBoxEditor依赖java虚拟机 , 所以要先安装 java. jTessBoxEditor下载地址: https://sourceforge.net/projects/vietocr/ ...

  5. Error "Client wants topic A to have B, but our version has C. Dropping connection."

    ROS problem 出现这个问题的原因是话题上的消息类型和订阅节点指定的消息类型不匹配.

  6. [转] netstat 查看TCP状态值

    转自 https://www.cnblogs.com/yuyutianxia/p/4970380.html netstat 查看TCP状态值   一.TCP 状态值 netstat -n | awk ...

  7. SpringSecurity基于数据库RBAC数据模型控制权限

    ⒈通用RBAC(Role - Based Access Control)数据模型 ⒉如何使用 1. package cn.coreqi.ssoserver.rbac; import org.sprin ...

  8. dubbo源码分析6——SPI机制中的AOP

    在 ExtensionLoader 类的loadFile方法中有下图的这段代码: 类如现在这个ExtensionLoader中的type 是Protocol.class,也就是SPI接口的实现类中Xx ...

  9. 用css解决table文字溢出控制td显示字数

    场景: 最左边这栏我不行让他换行,怎么办呢? 下面是解决办法: table{ width:100px; table-layout:fixed;/* 只有定义了表格的布局算法为fixed,下面td的定义 ...

  10. 二层环路保护,SEP多实例的配置

    作者:邓聪聪 智能以太保护SEP(Smart Ethernet Protection)是一种专用于以太网链路层的环网协议.SEP是一种以太环路保护机制,它通过有选择性地阻塞网络环路冗余链路,来达到消除 ...