操作文件方法

时间:2022-07-17 09:34:58
能调用方法的一定是对象
文件操作中,读写不能同时进行
想操作文件,首先要创建一个文件
 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)