python如何对文件进行操作
admin
2023-07-20 18:22:19
0

首先看看在pycharm输入文件句柄,怎样显示他的定义

f = open('student_msg', encoding='utf-8', mode='a+')  # 打开一个文件,赋值给f

print(type(f), f) # f文件句柄是属于一个类叫,也是可迭代对象。(io ---> input and out)

print(dir(f))   # 打印这个类的所有属性和方法

['_CHUNK_SIZE', 'class', 'del', 'delattr', 'dict', 'dir', 'doc', 'enter', 'eq', 'exit', 'format', 'ge', 'getattribute', 'getstate', 'gt', 'hash', 'init', 'init_subclass', 'iter', 'le', 'lt', 'ne', 'new', 'next', 'reduce', 'reduce_ex', 'repr', 'setattr', 'sizeof', 'str', 'subclasshook', '_checkClosed', '_checkReadable', '_checkSeekable', '_checkWritable', '_finalizing', 'buffer', 'close', 'closed', 'detach', 'encoding', 'errors', 'fileno', 'flush', 'isatty', 'line_buffering', 'mode', 'name', 'newlines', 'read', 'readable', 'readline', 'readlines', 'reconfigure', 'seek', 'seekable', 'tell', 'truncate', 'writable', 'write', 'write_through', 'writelines']

print(f.dict)  # f 这个实例化对象中的属性 {'mode': 'a+'}

源码对其的解释定义
'''
========= ===============================================================
Character Meaning


'r'       open for reading (default)  默认只读
'w'       open for writing, truncating the file first  首先把文件截断(全删了)
'x'       create a new file and open it for writing
'a'       open for writing, appending to the end of the file if it exists  追加模式
'b'       binary mode  二进制模式,打开图片或者非文本格式时
't'       text mode (default)  默认读取文本
'+'       open a disk file for updating (reading and writing)  可读可写
========= ===============================================================

'''
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
文件的操作使用的频率还是很高,这几种方法很容易弄混,为了避免以后出现偏差,现在我把几种常用的方法整理透。
一,.readline() 和 .readlines() 目的是浏览,查找文件中的内容用什么模式。先看用六种方式执行的结果。
在register文件中有以下内容,看下分别执行这六种方式返回的结果
”’
这些是文件中的内容
dumingjun
mickle|male
”’

mode='r'

with open('register', encoding='utf-8', mode='r') as f:
print(f.readline())
print(f.readlines())

运行结果:(文件中内容无变化)

'''
这些是文件中的内容

['dumingjun\n', 'mickle|male']
'''

mode='r+'

with open('register', encoding='utf-8', mode='r+') as f:
print(f.readline())
print(f.readlines())

运行结果:(文件中内容无变化)

'''
这些是文件中的内容    # 先读了一行

['dumingjun\n', 'mickle|male']  # 然后往下执行,把每行作为一个字符串放入列表这个容器中,换行符为\n
'''

mode='w'

with open('register', encoding='utf-8', mode='w') as f:
print(f.readline())
print(f.readlines())

运行结果:(文件中已经没有内容了)

'''
Traceback (most recent call last):
print(f.readline())
io.UnsupportedOperation: not readable   # 报错原因:’w‘模式是无法读的,只要看到’w‘,先把文件全清空
'''

mode='w+'

with open('register', encoding='utf-8', mode='w+') as f:
print(f.readline())
print(f.readlines())

运行结果:(文件内容已经为空)

'''

先清空,然后接下来执行了f.readline() 由于为空,所以返回了空的字符

[]    # 接下来执行f.readlines(), 返回一个空列表
'''

mode='a'

with open('register', encoding='utf-8', mode='a') as f:
print(f.readline())
print(f.readlines())

运行结果:(文件内容不变)

'''
Traceback (most recent call last):
print(f.readline())
io.UnsupportedOperation: not readable  # 报错原因,’a‘模式只能add,增加,不可读,因为’a'模式进去时光标自动放在文件的末尾。
'''

mode='a+'

with open('register', encoding='utf-8', mode='a+') as f:
print(f.readline())
print(f.readlines())

运行结果:(文件内容不变)

'''

因为光标是放在最后,所以读取的内容为空

[]     # 同理redlines()返回的是一个空列表。
'''
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
以上代码的内容显示在图片上:
这里写图片描述
这里写图片描述
这里写图片描述
总结
这里写图片描述
阅读,查找相关内容,只能用‘r’或 ‘r+’模式

二 现在要新建一个文件,并且添加内容,先看看五种方法运行的结果

'''
创建名为'msg'的文件,并写入内容以下内容:
’Duminjun is swimming\n今晚吃鸡‘
'''

r模式就不用试了,r只能读,试试r+模式

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

f.write('Duminjun is swimming\n今晚吃鸡')

运行结果:

'''
Traceback (most recent call last):
with open('msg', encoding='utf-8', mode='r+') as f:
FileNotFoundError: [Errno 2] No such file or directory: 'msg'  # 没有名为‘msg’的文件,证明r+模式不可添加文件
'''

a 模式

with open('msg', encoding='utf-8', mode='a') as f:

f.write('Duminjun is swimming\n今晚吃鸡')

#

运行结果(已经在本目录添加了‘msg’的文件,并且打开文件显示了以下内容:

'''
Duminjun is swimming   # a 模式可以创建文件并写入
今晚吃鸡
'''

a+模式

with open('msg', encoding='utf-8', mode='a+') as f:

f.write('Duminjun is swimming\n今晚吃鸡')

运行结果:和以上a运行结果一样

w模式

with open('msg', encoding='utf-8', mode='w') as f:

f.write('Duminjun is swimming\n今晚吃鸡')

结果:和a模式一样

w+ 模式

with open('msg4', encoding='utf-8', mode='w+') as f:

f.write('Duminjun is swimming\n今晚吃鸡')

运行结果:和a模式行的结果一样

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
图示:
这里写图片描述

三 如果有名为’msg‘的文件里面有’Duminjun is swimming\n今晚吃鸡‘这些内容,现在要增加以下内容
’\nLaura is a playing tennis,What are you dong?’ 试试这几种方法的效果

r

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

f.write('\nLaura is a playing tennis,What are you dong?')

运行结果:

'''
Traceback (most recent call last):
f.write('\nLaura is a playing tennis,What are you dong?')
io.UnsupportedOperation: not writable          # f这个实例化对象中没有可读这一属性
'''

r +

with open('msg', encoding='utf-8', mode='r+') as f:

f.write('\nLaura is a playing tennis,What are you dong?')

运行结果:(没有报错,文件内容如下:)

'''

Laura is a playing tennis,What are you dong?s swimming
今晚吃鸡            # 添加的内容已经插入到了最前面,r+模式可以写入文件,但是进入文件句柄时光标在最前面
'''

如果想要r+模式增加内容到文末,可以先读完全部内容,光标就到了最后,然后在把内容写入文件

with open('msg', encoding='utf-8', mode='r+') as f:

f.readlines()

f.write('\nLaura is a playing tennis,What are you dong?')

运行结果(文件内容如下):

'''
Duminjun is swimming
今晚吃鸡
Laura is a playing tennis,What are you dong?
'''

w

with open('msg', encoding='utf-8', mode='w') as f:

f.write('\nLaura is a playing tennis,What are you dong?')

运行结果,文件中显示以下内容:

'''

Laura is a playing tennis,What are you dong?  # 原文件内容全部清空,写入了新增加的内容
'''

w+

with open('msg', encoding='utf-8', mode='w+') as f:

f.write('\nLaura is a playing tennis,What are you dong?')

运行结果:和w运行结果一样

a

with open('msg', encoding='utf-8', mode='a') as f:

f.write('\nLaura is a playing tennis,What are you dong?')

#

运行结果,文件内容如下

'''
Duminjun is swimming
今晚吃鸡
Laura is a playing tennis,What are you dong?   # 已经成功到文末
'''

a+

with open('msg', encoding='utf-8', mode='a+') as f:

f.write('\nLaura is a playing tennis,What are you dong?')

运行结果:和a模式结果一样

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
图示
这里写图片描述
这里写图片描述

四,例题:写函数,用户传入修改的文件名,与要修改的内容,执行函数,完成整个文件的批量修改操作

def modify_update():
file_name = input('please input the file name: ').strip()
modify_content = input('please input the content to modified: ')
new_content = input('please input new content you want to replace: ')
with open('{}'.format(file_name), encoding='utf-8', mode='r+') as f, \
open('msk5', encoding='utf-8', mode='w+') as f1:            # 打开两个文件句柄,一个读原文档,一个写入修改后的内容
for i in f:
f1.write(i.replace('{}'.format(modify_content), '{}'.format(new_content)))

边循环原文件每一行,边添加新的一行到另外一个文件,如果replace没有找到旧词,字符串不会做任何修改,所以不用if...else语句

'''
w,w+在一个句柄里操作不会每次都清空,只有重新以w,w+模式打开一个句柄并且使用f.write()才会清空,就是说两个句柄是没有

相关内容

热门资讯

放弃出片的中产,挤爆“旅游兴趣... 六月到了,牛马们一年一度的出走季也到了。但这个端午假期,朋友圈的画风有点不对——年轻人好像集体抛弃了...
莫斯科再遭大规模袭击,76架乌... 据凤凰卫视报道,俄罗斯莫斯科6月19日再次遭到乌军大规模无人机袭击,俄军至少击落76架乌军无人机。俄...
民进党当局扬言查处与大陆签约的... 海峡导报综合报道 中国国民党籍台中市长卢秀燕19日陪嘉义市长参选人张启楷扫街拜票,对陆委会扬言要查处...
挪威将禁止小学生使用生成式人工... 挪威首相斯特勒19日表示,为防止对学习产生负面影响,挪威将基本全面禁止小学生使用生成式人工智能(AI...
优必思取得移动式称重包装机专利... 国家知识产权局信息显示,湖南优必思自动化科技有限公司取得一项名为“一种移动式称重包装机”的专利,授权...
原创 超... 华为在上半年的新机较多,比如华为nova 16系列、华为Pura 90系列、华为Pura X Max...
原创 荣... 纵观今年618手机销量榜单,1500元价位段出现了一匹黑马——荣耀X70焕新版,长期稳居同价位销量榜...
led灯不亮故障解决方法 当 LED 灯不亮时,可以按照以下步骤进行故障排除和解决:1. 检查电源:确保 LED 灯的电源正常...
led吊灯忽明忽暗怎么回事 LED 吊灯忽明忽暗可能由以下原因导致:1. 电源问题:吊灯的电源供应不稳定,可能是电压波动、电源线...
抽油烟机抽得少怎么回事 抽油烟机是我们厨房中重要的设备之一,它能有效地吸收烹饪的烟味和油蒸气,让我们的厨房变得更加清新和干净...