jeck猫
你担忧的有一半是伪问题,1w多个元素的字典并不大,而且字典的时间效率很好。不管多么“高效”的工具都要逐行读取文本,因为这个问题的逻辑是这样。你只要注意边读行,边处理,边写入。不要一次全部读入再遍历list,浪费内存。参考代码:#!/usr/bin/envpython#-*-coding:utf-8-*-defget_config(filename):config_dic={}withopen(filename,'r')asf:forlinf:v,k=l.strip().split(';')config_dic[k]=vreturnconfig_dicdefconvert_line(src,cnf):head,body=src.split(';',maxsplit=1)head_r=cnf[head]return';'.join((head_r,body))deftrans_obj_file(src,dst,cnf):withopen(dst,'w')asfw:withopen(src,'r')asfr:forlrinfr:lw=convert_line(lr,cnf)fw.write(lw)if__name__=="__main__":config_file="conf"src_obj_file="object"dst_obj_file="object_1"cnf=get_config(config_file)trans_obj_file(src_obj_file,dst_obj_file,cnf)