马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 猪猪虾 于 2020-4-1 13:54 编辑 #0. 编写一个程序,这次要求使用pickle将文件
#(record.txt 里的对话按照以下要求腌制成不同文件(没错,是第29讲的内容小改,考考你自己能写出来吗?):
#•小甲鱼的对话单独保存为boy_*.txt的文件(去掉“小甲鱼:”)
#•小客服的对话单独保存为girl_*.txt的文件(去掉“小客服:”)
#•文件中总共有三段对话,分别保存为boy_1.txt, girl_1.txt,boy_2.txt, girl_2.txt, boy_3.txt,
# gril_3.txt共6个文件(提示:文件中不同的对话间已经使用“==========”分割)
import pickle
f=open(r"C:\Users\Administrator\Desktop\python\record_2.txt","r")
boy=[]
girl=[]
count=1
for each_line in f:
if each_line[:4] != '====':
[former,latter]= each_line.split(':',1)
if each_line.startswith("小甲鱼:"):
boy.append(latter)
elif each_line.startswith("小客服:"):
girl.append(latter)
else:
boy_new_file = 'boy_'+ str(count) + '.txt'
girl_new_file = 'girl_' + str(count) + '.txt'
boy_new_file=open('boy.txt','wb')
girl_new_file=open('girl.txt','wb')
pickle.dump(boy,boy_new_file)
pickle.dump(girl,girl_new_file)
boy_new_file.close()
girl_new_file.close()
boy=[]
girl=[]
count+=1
boy_new_file = 'boy_'+ str(count) + '.txt'
girl_new_file = 'girl_' + str(count) + '.txt'
boy_new_file=open('boy.txt','wb')
girl_new_file=open('girl.txt','wb')
pickle.dump(boy,boy_new_file)
pickle.dump(girl,girl_new_file)
boy_new_file.close()
girl_new_file.close()
f.close()
第24和25行,open文件的时候,文件名一直是同一个,所以每次都会覆盖前一个文件
应该是boy_new_file=open(boy_new_file ,'wb') girl_new_file=open(girl_new_file,'wb')
第41行业是一样的问题
|