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