python io操作

一次性读取

 1 # 读取文件
 2 
 3 # 默认打开文件的方式是只读
 4 file = None
 5 try:
 6     file = open("f:/test.sql")
 7     print(file.name)  # f:/test.sql
 8 
 9     # read是一次性读取,调用read之后会把指针移动到文件的末尾,再次调用返回空字符串
10     content = file.read()
11 
12     # print("----" + file.read())
13     print(content)
14 except Exception as log:
15     print("找不到文件")
16 finally:
17     if file:
18         file.close()
19 
20 # 使用with语句,with语句会自动帮我们调用close()
21 with open("f:/test.sql") as f:
22     print(f.read())
23 
24 # 使用with 可以创建单层级文件
25 # with open("f:/ooooooooooooooooa.sql","w") as f:
26 #     f.write("asd")

逐行读取

 1 # 逐行读取
 2 
 3 file = None
 4 try:
 5     file = open("f:/test.sql")
 6 
 7     line = file.readline()
 8     while line is not None and line.strip() != "":
 9         print(line)
10         line = file.readline()
11 
12 except Exception as info:
13     print("文件未找到")
14 finally:
15     if file is not  None:
16         file.close()

 逐行读取并写入

 1 # 逐行读取并写入
 2 rs = None
 3 ws = None
 4 try:
 5     rs = open("f:/test.sql")
 6     ws = open("f:/test_copy.sql", "w")
 7 
 8     # 读取并写入
 9     while True:
10         line = rs.readline()
11 
12         # 如果line为None或者line为空字符串
13         if line is None or line.strip() == "": # 或者 not line
14             break
15         ws.write(line)
16 
17 
18 except Exception as info:
19     print(info)
20 finally:
21     if rs:
22         rs.close()
23     if ws:
24         ws.close()

 字节流

 1 # -*- coding: utf-8 -*-
 2 # @author: Tele
 3 # @Time  : 2019/04/04 下午 12:17
 4 # 字节流读写
 5 rs = open("F:/ftp_mypc/a.flv", "rb")
 6 ws = open("f:/a_copy.flv", "wb")
 7 buffer = 1024
 8 while True:
 9     content = rs.read(buffer)
10     if not content:
11         break
12     ws.write(content)
13 
14 if rs:
15     rs.close()
16 if ws:
17     ws.close()

 

posted @ 2019-03-14 21:51  tele  阅读(454)  评论(0编辑  收藏  举报