python学习笔记1合并文件
初始两个txt文件:
代码如下:
#打开文件
ftele1=open(r'TeleAddressBook.txt','rb')#出现中文,避免乱码使用‘rb’模式ftele2=open(r'EmailAddressBook.txt','rb')
ftele1.readline()
ftele2.readline()
#列表lines1和lines2分别存储了电话信息和邮箱信息的二进制数据
lines1=ftele1.readlines()
lines2=ftele2.readlines()
#建立空列表用于存储姓名电话Email信息
list1_name=[]
list1_tele=[]
list2_name=[]
list2_email=[]
for line in lines1:#获取第一个文本中的姓名和电话信息
elements=line.split() #由于elements中是中文的'utf-8'二进制编码,用decode解码
list1_name.append(str(elements[0].decode('utf-8')))
list1_tele.append(str(elements[1].decode('utf-8')))
for line in lines2:#获取第二个文本中的姓名和邮件信息
elements=line.split()
list2_name.append(str(elements[0].decode('utf-8')))
list2_email.append(str(elements[1].decode('utf-8')))
#生成新数据
lines=[]
lines.append('姓名\t 电话 \t 邮箱\n')
#按索引方式遍历姓名列表1
for i in range(len(list1_name)):
s=''
if list1_name[i] in list2_name:
j=list2_name.index(list1_name[i]) #找到姓名列表1对应列表2中的姓名
s='\t'.join([list1_name[i],list1_tele[i],list2_email[j]])
s+='\n'
else:
s='\t'.join([list1_name[i],list1_tele[i],str(' ----- ')])
s+='\n'
lines.append(s)
#处理姓名列表2中剩余的姓名
for i in range(len(list2_name)):
s=''
if list2_name[i] not in list1_name:
s='\t'.join([list2_name[i],str(' ---- '),list2_email[i]])
s+='\n'
lines.append(s)
ftele3=open('AddressBook.txt','w')
ftele3.writelines(lines)
ftele3.close()
ftele1.close()
ftele2.close()
print("The addressbooks are merged!")
文件合并后结果: