import os
技术交流QQ群:1027579432,欢迎你的加入!
Q1.有一个jsonline格式的文件file.txt大小约为10K
``` def get_lines(): l = [] with open("file.txt", 'rb') as f: for eachline in f: l.append(eachline) return l ```
- 现在要处理一个大小为10G的文件,但是内存只有4G,如果在只修改get_lines 函数而其他代码保持不变的情况下,应该如何实现?需要考虑的问题都有那些?
- 要考虑的问题有:内存只有4G无法一次性读入10G文件,需要分批读入分批读入数据要记录每次读入数据的位置。分批每次读取数据的大小,太小会在读取操作花费过多时间。
def get_liness(): l = [] with open("file.txt", 'rb') as f: data = f.readlines(60000) l.append(data) yield l
Q2:补充缺失的代码
def print_file_path(parent_path): for child in os.listdir(parent_path): child_path = os.path.join(parent_path, child) if os.path.isdir(child_path): # 判断child_path是否是一个目录 print_file_path(child_path) else: print(child_path) if __name__ == '__main__': for e in get_lines(): process(e) # 处理每一行的数据