11 python初学 (文件)

对文件的操作分为 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 函数:将字符串变回数据类型

posted on 2019-01-03 00:39  mlllily  阅读(204)  评论(0编辑  收藏  举报