操作文件方法

发布时间:2019-04-09 21:42:19编辑:auto阅读(1818)

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

     

关键字