python--文件操作,enumerate

简介: python--文件操作,enumerate

文件操作


  • r,只读模式(默认)。
  • w,只写模式。【不可读;不存在则创建;存在则删除内容;】
  • a,追加模式。【可读; 不存在则创建;存在则只追加内容;】
  • "+" 表示可以同时读写某个文件
  • r+,可读写文件。【可读;可写;可追加】
  • w+,写读
  • a+,同a

wb, rb, ab : 处理的是非文本

f = open('yest2', 'w', encoding='utf-8')  # 指定utf-8打开,不指定按电脑系统的gbk打开,打不开会报错
f.write('\n我爱北京天安门, \n')
f.write('天安门上太阳升. ')
f.flush()  # 刷新
f.close()

新建了一个yest2的文本文档,里面写了我爱北京天安门, 天安门上太阳升.重新修改时会将里面的覆盖。如果w改为a(append),则会在上面两句话的后面加上新的,不会覆盖,w会新建一个文件,如果之前有同名的文件,则会把之前的覆盖。不用print,内容直接会出现在yest2里

f = open('yestday2', 'r', encoding='utf-8')
data1 = f.read()
data2 = f.read()
print(data1)
print(data2)
# 只会打印出data1的数据,因为data1已经读到最后了,data2它还是往下读,已经没有数据了,所以它为空。
f = open('yestday2', 'r', encoding='utf-8')
print(f.readlines())

结果:

['1111111\n', '222222\n', '33333333\n', '4444444']
# readlines按行打印在一个列表里
f = open('yestday2', 'r', encoding='utf-8')
print(f.readline())
print(f.readline())
# 打印出了两行
f = open('yestday2', 'r', encoding='utf-8')
for i in range(5):
    print(f.readline())
# 读了五行

创建一个文件名为软件测试,里面写一句我是做软件的

f = open("软件测试", mode="rb")  # 读取的内容直接就是字节
bs = f.read()
print(bs)
print(bs.decode("utf-8"))  # 需要解码
f.close()

结果:

b'\xe6\x88\x91\xe6\x98\xaf\xe5\x81\x9a\xe8\xbd\xaf\xe4\xbb\xb6\xe7\x9a\x84'
我是做软件的

r+模式, 默认情况下光标在文件的开头, 必须先读, 后写

f = open("软件测试", mode="r+", encoding="utf-8")
s = f.read()
f.write("周润发")
f.flush()
f.close()
print(s)

r+在没有任何操作之前进行写. 在开头写 . 如果读取了一些内容. 再写, 写入的是最后

f = open("软件测试", mode="r+", encoding="utf-8")
f.read(3)
f.seek(6)  # 移动到xx位置
print(f.read())

结果:

做软件的
搞it的
测试
# 移动到开头: f.seek(0)  开头
# 移动到末尾: f.seek(0, 2)   末尾 第二个参数有三个值. 0: 再开头,  1: 在当前, 2: 末尾
# seek(n) 光标移动到n位置, 注意, 移动的单位是byte. 所以如果是UTF8的中⽂部分要是3的倍数.
f = open('yestday2', 'r', encoding='utf-8')
print(f.tell())  # 光标在第几个字符后   0 
print(f.readline())  # 打印一行
print(f.read(5))  # 打印5个字符
print(f.readline())
print(f.tell())
f.seek(10)  # 光标返回到第十个字符,开始就是0
print(f.readline())  # 光标之后的一行打印出来
f.truncate(10)  # 截取多少个字符,从文件头开始,有seek也是从头开始的
f = open('yestday2', 'r', encoding='utf-8')
print(f.encoding)  # 返回编码
print(f.name)  # 打印名称
print(f.readable())  # 判断文件是否可读
print(f.writable())  # 判断文件是否可写
print(f.seekable())  # 判断光标是否可返回

结果:

utf-8
yestday2
True
False
True
f = open('yestday2', 'r', encoding='utf-8')
f_f = open('yestday7', 'w', encoding='utf-8')
for line in f:
    if '那三年的第一年写的' in line:
        line = line.replace('那三年的第一年写的', '那三年的每  一天写的')
    f_f.write(line)
f.close()
f_f.close()

判断三年的第一年写的在不在line里面,如果在,执行line=line.replace('那三年的第一年写的','那三年的每  一天写的')将里面的文字替换,然后执行f_f.write(line),如果不在,直接执行f_f.write(line)

import os
with open("吃的", mode="r", encoding="utf-8") as f1, \
        open("吃的_副本", mode="w", encoding="utf-8") as f2:
    for line in f1:
        s = line.replace("菜", "肉")
        f2.write(s)
os.remove("吃的")  # 删除文件
os.rename("吃的_副本", "吃的")  # 重命名文件

with open('yestday2','r',encoding='utf-8') as f:

with就是程序执行完后系统自行关闭,不用输close(),as f 将前面的文件赋值给 f


enumerate


作用:可以打印出下标

之前打印下标是这样操作的

list1 = ["这", "是", "一个", "测试"]
for i in range(len(list1)):
    print(i, list1[i])

结果:

0 这
1 是
2 一个
3 测试

使用enumerate

list1 = ["这", "是", "一个", "测试"]
for index, item in enumerate(list1):
    print(index, item)

结果:

0 这
1 是
2 一个
3 测试
for index, line in enumerate(f.readlines()):
    if index == 9:
        print('----我是分割线----------')
        continue
    print(line.strip())  # 去掉空格

打印了九行后,打印出----我是分割线----------,返回for,从第十行接着往下打印

import sys, time
for i in range(20):
    sys.stdout.write('*')  # 打印#标准输出到屏幕,stdout标准输出
    sys.stdout.flush()  # 及时刷新,如果没有,20个 *10s之后一起打印出来
    time.sleep(0.5)  # 打印一个,等待时间0.5s

每隔0.5s打印出来一个*


相关文章
|
2月前
|
安全 Python
Python语言中常用的文件操作方法探讨
通过上述方法的结合使用,我们可以构筑出强大并且可靠的文件操作逻辑,切实解决日常编程中遇到的文件处理问题。
157 72
|
2月前
|
移动开发 安全 Linux
Python文件操作的"保险箱":with语句深度实战指南
本文深入解析Python中`with`语句的原理与高级应用,通过“保险箱”类比,形象展示资源管理机制。从上下文管理协议到实战场景,涵盖文件、数据库、网络等多种资源的高效安全处理方式,助你写出更优雅、可靠的代码。
70 1
|
3月前
|
缓存 数据库连接 数据库
Python文件操作的“保险箱”:with语句深度实战指南
本文深入探讨Python中with语句在文件操作中的应用及其优势。首先介绍其底层原理,基于上下文管理协议自动管理资源的获取与释放,避免手动关闭文件导致的资源泄漏问题。接着通过基础文件读写、异常处理进阶和复合资源管理等实战场景解析with语句的便捷性与安全性。同时,阐述如何自定义上下文管理器以满足特定需求,并分析其性能考量及优化策略。最后总结实战经验,强调优先使用内置管理器、明确异常处理以及保持代码可读性的重要性,助力开发者高效编写健壮的程序。
73 1
|
3月前
|
自然语言处理 安全 JavaScript
Python文件操作的“保险箱”:with语句深度实战指南
Python中的`with`语句是文件操作和资源管理的强大工具,如同一个智能保险箱,自动处理打开和关闭操作,避免手动管理可能引发的错误。它通过上下文管理协议(`__enter__`和`__exit__`方法)确保资源在使用后正确释放。无论是逐块读取大文件、同时读写文件,还是处理特殊编码文件,`with`语句都能简化代码并提高安全性。此外,自定义上下文管理器可扩展到数据库连接等场景,而常见错误如重复关闭文件或忽略异常也需注意。结合生成器表达式批量处理文件时,`with`语句仍能保持高效和安全。总之,`with`语句是资源管理的瑞士军刀,让复杂操作变得简单可靠。
72 1
|
3月前
|
数据采集 运维 BI
Python 文件操作进阶|使用 shutil 实现高效文件复制
在开发和运维中,处理大量文件是常见需求,如备份配置、归档日志或构建部署包。手动复制粘贴已无法满足高效需求!Python 的 `shutil` 模块提供了强大的文件操作功能,支持单文件复制、目录树迁移及自动化任务构建。本文详解 `shutil.copy()` 基础用法与进阶技巧,如批量复制、自动路径检测、时间戳命名备份等,助你实现高效自动化。结合实战案例(如自动备份系统),让你的代码更专业!学习后,欢迎交流心得,一起精进 Python 技能。关注我,获取更多编程技巧与源码分享!
|
监控 Java 数据处理
文件操作不再难!Python系统编程实战,带你轻松驾驭文件系统与I/O
【7月更文挑战第31天】在 Python 系统编程中, 文件操作与 I/O 管理至关重要。
141 2
|
11月前
|
存储 Python
Python文件操作(1)
【10月更文挑战第17天】
194 60
Python文件操作(1)
|
11月前
|
数据采集 存储 Python
Python文件操作2
【10月更文挑战第18天】
70 2
Python文件操作2
|
IDE 测试技术 开发工具
Python接口自动化测试框架(基础篇)-- 不只是txt的文件操作
本文介绍了Python中的文件操作方法,包括使用open()打开文件、close()关闭文件、read()读取内容、readline()读取单行、readlines()读取多行、write()写入内容以及writelines()写入多行的方法。同时,探讨了文件操作模式和编码问题,并扩展了上下文管理器with...as的使用,以及对图片和音频文件操作的思考和练习。
109 1
Python接口自动化测试框架(基础篇)-- 不只是txt的文件操作
|
12月前
|
存储 Python
Python文件操作
Python文件操作

热门文章

最新文章

推荐镜像

更多