能调用方法的一定是对象
文件操作中,读写不能同时进行
想操作文件,首先要创建一个文件
1 '''第一,读文件'''
2 f=open('test','r',encoding='utf8') #这句就拿到了文件里面的所有内容,并打开。
3 data = f.read() #read是一个字符一个字符的读取内容,效率低。
4 print(data)
5 f.close() #关闭文件
6
7
8
9
10 '''第二,写文件'''
11 #写文件,会把文件原有的内容先清空,然后再写入需要写的内容
12 f=open('test','w',encoding='utf8')
13 f.write('hello world\n')
14 f.close()
15
16
17 '''第三,追加文件内容'''
18 #'a'是在原有文件后面添加新的内容,不会删除原文件
19 f= open('test','a',encoding='utf8')
20 f.write('\n添加的内容')
21 f.close()
22
23
24
25 #如果写的文件不存在(下面‘测试文件2’写之前是不存在的),就先创建一个文件,然后再写
26 f= open('test2','w',encoding='utf8')
27 f.write('hello world\n')
28 f.write('Chris')
29 f.close()
30
31
32
33 #读取固定字符
34 f = open('test','r',encoding='utf8')
35 a=f.read(5) #读取5个字符
36 print(a)
37 f.close()
38
39
40 #把所有内容变成列表打印出来,然后可以通过列表的方式把内容再输出来。
41 f = open('test','r',encoding='utf8')
42 b=f.readlines()
43 print(b)
44 f.close()
45
46 #用read,打印有所的文件内容,用readlines,可以打印需要的内容,而且会把内容做成#列表放到内存中,但是如果内容很大,这样内存放不下,这是readlines的不足
47
48
49
50 #循环输出文件内容
51 number = 0
52 for i in f.readlines():
53 number+=1
54 if number==6:
55 # i=''.join((i.strip(),'fjdsl')) #字符串的拼接用join
56 print(i.strip())
57 f.close()
58
59
60
61 #用f.readlines,会占用很多内存,还有一种就是直接取句柄名,这样不会占用内存
62 #以下用f代替f.readlines,这是最好的,尽量不用readlines。
63
64 for i in f: #这样操作是for循环内部将f对象做成一个迭代器,用一行取一行
65 print(i.strip())
66
67
68
69
70
71 #打印光标的位置
72 #tell当打印英文时,一个字母就是一个字符,占一个位置,当
73 #打印中文时,tell会认为一个中文是一个字符,占三个位置,
74 # 即当光标在第一个位置0时,当打印了3个中文,光标会在位置9
75
76 print(f.tell())
77 print(f.read(3).strip())
78 print(f.tell())
79
80
81
82
83
84 #调整光标的位置 seek
85 print(f.seek(0)) #将光标调整到零的位置
86 print(f.read(4))
87 print(f.tell())
88 f.seek(1)
89 print(f.tell())
1 f=open('hello','w')
2 f.write('hello world!')
3 f.flush() #可以立刻把缓存在内存上的数据保存在磁盘上,可以做进度条。
4
5
6
7 #一个简答的进度测试
8 import sys,time
9 for i in range(10):
10 sys.stdout.write('.')
11 sys.stdout.flush()
12 time.sleep(0.1)
13
14
15
16
17 #truncate(),截断字符
18 f = open('test','w',encoding='utf8')
19 #在'w'的情况下,用truncate会先把内容清空,然后再在指定的位置截断
20 f.truncate(5)
21 f.close()
22
23
24 #在'a'的情况下,可以在指定的位置截断剩下的内容,保留指定位置之前的内容
25 f= open('test','a',encoding='utf8')
26 f.truncate(20)
27 f.close()
28
29
30 # #r+,w+,a+
31 f=open('test','r+',encoding='utf8')
32 print(f.readline())
33 f.write('hello world!')
34 f.seek(0)
35 print(f.readline())
36 f.close()
37
38
39
40
41
42 #把字典转成字符串存到文件里面,需要拿出来时
43 #需要再把字符串转成字典,用eval转成原来的数据类型 ,eval的功能就是实现字符串与字#典列表和元组等数据之间的转换。
44 a=str({'beijing':{'1':111}})
45 print(type(a))
46 print(a)
47 a=eval(a)
48 print(type(a))
49 print(a['beijing'])
50
51
52
53
54
55 #关于文件用完以后需要关闭文件的另一个用法
56 with open('log','r') as f:
57 #上面的这种等价于:
58 f=open('log','r')
59 #用with语句,当文件的操作结束后,会自动关闭文件,就不用再f.close()了
60
61
62
63 #当需要同时操作多个文件时,同样可以用with。
64 with open('log1','r',encoding='utf8') as f_read, open('log2','w',encoding='utf8') as f_write:
65 for line in f_read:
66 f_write.write(line)