对文件的操作分为 3 步:

  1. 打开文件;

    f = open('望月怀古', 'r', encoding='utf8')   # 路径可以写绝对路径,也可以写相对路径;
  2. 操作
  3. 关闭文件; f.close()

with 方式打开文件:使用 with 语句,当 with 代码块执行完毕之后,内部会自动关闭并释放文件资源。这样可避免打开文件后忘记关闭。

在 python 2.7 后,with 又支持对多个文件进行上下文管理。

with open('望月怀古', 'r', encoding='utf8') as f:
print(f.readline())
with open('望月怀古', 'r', encoding='utf8') as f1, open('望月怀古1', 'w', encoding='utf8') as f2:
pass

只读模式:r

f = open('望月怀古', 'r', encoding='utf8')
data = f.read(5) # 读取 5 个字符: 1 个汉字和 1 个 英文字母都算是 1 个字符
print(data)
f.close()

写模式:w。 

# w:写操作。 在 f 对象被创建的时候就会将原来的文件清空,重新写操作。
# 如果没有该文件,则先会自动创建一个,在进行写入
f = open('望月怀古1', 'w', encoding='utf8')
f.write('望月怀古')
f.write(' 张九龄') # 会紧跟在上一句之后写入。
f.close()

在文件后继续添加:a

# a:append 直接在文件后面追加
f = open('望月怀古1', 'a', encoding='utf8')
print(f.fileno()) # 打印文件句柄
f.write('\nHello world')
f.close()

文件操作方法:

1. readline()

如果想要读取文件某一行的内容(如第五行),使用 linecache

linecache是专门支持读取大文件,而且支持行式读取的函数库。 linecache预先把文件读入缓存起来,后面如果你访问该文件的话就不再从硬盘读取

import linecache

str = linecache.getline(filename,linenum)

# 读取一行数据。 读取一行后,光标移动了,如果文件没有被关闭,下次会从光标处继续读
f = open('望月怀古', 'r', encoding='utf8')
f.readline()

2. readlines()

a. 可以通过 count = len(f.readlines) 来计算文件行数。但是对于大型文件不适用

b. 大型文件:使用循环处理。 for i in f: count += 1

c.str = linecache.getlines(filename)       str为列表形式,每一行为列表中的一个元素

print(f.readlines())  # 读取所有行,放进一个列表中输出

# readlines 读取出来的列表会被放进内存中进行保存,因此当文件很大时并不建议使用此方法。使用 for i in f,即可对每一行做输出
f = open('望月怀古', 'r', encoding='utf8')
# for i in f.readlines(): 不建议使用
for i in f:
print(i.strip())
f.close()

3. tell() :得到当前光标位置

f = open('望月怀古', 'r', encoding='utf8')
print(f.tell())
f.read(7)
print(f.tell()) >>> 0
>>> 7 # 如果是英文字符,则读取 7 个后,当前光标位置是 7
# 如果是中文字符,读取 7 个后,当前光标位置是 21.因为一个中文占 3 个字符

4. seek():调节当前光标位置

#hello world
#
f = open('望月怀古', 'r', encoding='utf8')
print(f.tell())
print(f.read(7))
print(f.tell()) f.seek(0) # 调节当前光标位置到0,从当前位置开始打印
print(f.read(4)) >>> 0
>>> hello w
>>> 7
>>> hell # 又从光标 0 的地方开始输出

 5. flush() :把缓存里的数据保存到磁盘里区

f.flush()

# flush 立即刷新写入。此段代码运行结果就是每隔 1 秒钟输出一个 * ,一共输出 10 个
import sys
import time
for i in range(10):
sys.stdout.write("*")
sys.stdout.flush()
time.sleep(1)

6.truncate():从某个字符处开始截断,将后面内容全部删除。

f = open('望月怀古1', 'a', encoding='utf8')
f.truncate(7)
f.close()
>>> hello w

7. fileno():得到文件描述符,返回一个整数。唯一的代表一个文件

8. f.isatty(): 判断是不是终端

9. f.readable(): 判断文件是不是可读的

10 . r+、 w+、 a+

# r+:即可读,又可以写的模式,是在 r 的基础上延伸出来的。1. 不会清空文件;2. 写的时候会在文件最后写
# w+:既可读又可写,是在 w 的基础上延伸出来的。1. 会清空文件 2. 写入之后光标会移动到当前写入字符后,再读取就没有内容,如果需要读取写入内容,就需要调节光标位置
# a+:既可读又可写,是在 a 的基础上延伸出来的。1. 不会清空文件 2. 光标初始默认定位在文件最后,因此需要读取时需要先调节光标位置 3. 写入时不论当前光标位置如何,都会在最后添加。
# r+:
f = open("望月怀古1", 'r+', encoding='utf8')
print(f.readline())
f.write("love you")
f.close() #w+:
f = open("望月怀古1", 'w+', encoding='utf8')
print(f.readline())
f.write("i love you")
print(f.tell())
f.seek(0)
print(f.readline())
f.close()
#a+:
f = open("望月怀古1", 'a+', encoding='utf8')
f.seek(4)
print(f.readline())
f.write("12345")
f.close()
 

# 实现将 望月怀古 第 2 行后添加字符串 “lily”

# 实现1: 此种实现的问题是,以为光标在第 2 行后面,就可以添加到正确的位置了。但是其实会添加到最后,因为就是这样的机制。
f = open("望月怀古", "r+", encoding='utf-8')
count = 0
for line in f:
count += 1
if count == 2:
f.write("lily")
f.close()

eval 函数:将字符串变回数据类型

11 python初学 (文件)的更多相关文章

  1. python初学--文件操作、字典

    文件读写 1.先打开文件 2.读取/写入内容 3.保存文件   文件的open模式有三种 1.w 写模式,它是不能读的 只要用w打开文件,文件中的东西都会被清空 w+, 写读模式,只要沾上w 就会清空 ...

  2. 11. python读写文件的多种方式

    一.txt文件 with open('users.txt','r') as user_file: data = user_file.readlines() users = [] for line in ...

  3. 孤荷凌寒自学python第四十五天Python初学基础基本结束的下阶段预安装准备

     孤荷凌寒自学python第四十五天Python初学基础基本结束的下阶段预安装准备 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 今天本来应当继续学习Python的数据库操作,但根据过去我自 ...

  4. python 读写文件和设置文件的字符编码

    一. python打开文件代码如下: f = open("d:\test.txt", "w") 说明:第一个参数是文件名称,包括路径:第二个参数是打开的模式mo ...

  5. Python初学笔记

    一.安装:直接通过软件管理程序,搜索Python,安装:安装过程中自定义路径,有个选项类似“add Python3.5 to Path”,勾选后便可以在cmd命令窗口,通过输入Python,启动Pyt ...

  6. Python的文件与文件夹操作

    Python的文件与文件夹操作 Python OS模块 1.重命名:os.rename(old, new) 2.删除:os.remove(file) 3.列出目录下的文件 :os.listdir(pa ...

  7. Python 读写文件操作

    python进行文件读写的函数是open或file file_handler = open(filename,,mode) Table mode 模式 描述 r 以读方式打开文件,可读取文件信息. w ...

  8. Python之文件与目录操作及压缩模块(os、shutil、zipfile、tarfile)

    Python中可以用于对文件和目录进行操作的内置模块包括: 模块/函数名称 功能描述 open()函数 文件读取或写入 os.path模块 文件路径操作 os模块 文件和目录简单操作 zipfile模 ...

  9. python之文件的读写和文件目录以及文件夹的操作实现代码

    这篇文章主要介绍了python之文件的读写和文件目录以及文件夹的操作实现代码,需要的朋友可以参考下 为了安全起见,最好还是给打开的文件对象指定一个名字,这样在完成操作之后可以迅速关闭文件,防止一些无用 ...

随机推荐

  1. 协程与Epoll的配合

    想快速了解协程与网络调用的原来么,那么请赶紧关闭本页,因为下面都是在扯淡. 这几天是端午假期,第一天大算照着网上一大堆基于ucontext来写协程的文章自己也写一个简单的协程实现.于是第一天我就开始动 ...

  2. Js 控制随机数概率

    如: 取 1~10 之间的随机数,那么他们的取值范围是: 整数 区间 概率 1 [0,1) 0.1 2 [1,2) 0.1 3 [2,3) 0.1 4 [3,4) 0.1 5 [4,5) 0.1 6 ...

  3. Android view显示在软键盘上方

    给EditText外加一个ScrollView,将高度设置统一,并给ScrollView设置属性 android:fillViewport="true".  注:ScrollVie ...

  4. Ambari架构源码解析

    1. Ambari介绍 Apache Ambari是一种基于Web的工具,支持Apache Hadoop集群的供应.管理和监控.Ambari已支持大多数Hadoop组件,包括HDFS.MapReduc ...

  5. 服务器端使用jstat定位GC问题的有关命令

    jstat命令可以查看堆内存各部分的使用量,以及加载类的数量. 命令的格式如下: jstat    [-命令选项]    [vmid]     [间隔时间/毫秒]      [查询次数]  注意!!! ...

  6. (后端)Spring手动回滚事务

    百度上查资料获得的 throw new RuntimeException(); 或者  TransactionAspectSupport.currentTransactionStatus().setR ...

  7. shell编程—注释、字符串和数组(四)

    shell注释 以#作为注释符号 shell中没有多行注释,只能一行加一个#号 字符串操作 1.拼接字符串 2.获取字符串长度 string=“khjf” echo ${#string} 3.提取子字 ...

  8. mssql sqlserver for xml EXPLICIT 用法详解说明

    摘要:下文通过举例的方式,详细说明"for xml EXPLICIT"关键字的用法,如下所示:实验环境:sql server 2008 R2 EXPLICIT的功能:将数据表采用特 ...

  9. C# Modbus协议中读取浮点数的操作方法

    输入参数P1,P2代表PLC中浮点数储存的两个寄存器获取的数据 public static float GetFloat(ushort P1, ushort P2) { int intSign, in ...

  10. c/c++ lambda 表达式 剖析

    lambda 表达式 剖析 大前提:捕获列表里变量的确定时机. 捕获列表和参数列表有区别,捕获列表里的变量,是在捕获的时间点就确定了,而不是在lambda调用时确定,参数列表是在调用时才确定.所以当捕 ...