零基础入门学习python的第二十九讲一个任务有些疑问
f = open('record.txt')boy = []
girl = []
count = 1
for each_line in f:
if each_line[:6] != '======':
(role, line_spoken) = each_line.split(':', 1)
if role == '小甲鱼':
boy.append(line_spoken)
if role == '小客服':
girl.append(line_spoken)
else:
file_name_boy = 'boy_' + str(count) + '.txt'
file_name_girl = 'girl_' + str(count) + '.txt'
boy_file = open(file_name_boy, 'w')
girl_file = open(file_name_girl, 'w')
boy_file.writelines(boy)
girl_file.writelines(girl)
boy_file.close()
girl_file.close()
boy = []
girl = []
count += 1
file_name_boy = 'boy_' + str(count) + '.txt'
file_name_girl = 'girl_' + str(count) + '.txt'
boy_file = open(file_name_boy, 'w')
girl_file = open(file_name_girl, 'w')
boy_file.writelines(boy)
girl_file.writelines(girl)
boy_file.close()
girl_file.close()
f.close()
这个是课堂小甲鱼的代码,任务是要将三段对话分别根据性别保存起来。但我有个地方不懂,就是 设置if each_line[:6] != '======':这个条件,不应该会将整个文档中的字符串都遍历一遍了吗,应该全部都保存进boy1和girl1文件里,为什么能形成分段保存的效果? for each_line in f: # 注意看这,这里的each_line是文件的每一行,没一行循环处理保存一次,并不是整个遍历
if each_line[:6] != '======':# 这个判断意思是每一行的前6个字符是‘======’ 自动分 看看这个注释能不能辅助理解
#定义写入函数
def save_file(boy,girl,count): #传入两个列表(用于存储对话内容)和一个计数器
file_name_boy='boy_'+str(count)+'.txt'#新建一系列文件,命名由字符串拼接
file_name_girl='girl_'+str(count)+'.txt'#同理
boy_file=open(file_name_boy,'w')#以写入方式打开
girl_file=open(file_name_girl,'w') #同理
boy_file.writelines(boy) #写入
girl_file.writelines(girl)
boy_file.close() #关闭
girl_file.close()
#定义切分函数
def spilt_file(file_name): #传入文件名
f = open(file_name,"r",encoding='UTF-8')
#关键点,编码方式 就这里换个编码形式
boy=[]
girl=[]
count=1
for each_line in f: #遍历原对话文件每一行
if each_line[:6]!='======':#以分割线判断
(role,line_spoken)=each_line.split(':',1)
#以:为界,分成元组,进行1次操作
if role =='小甲鱼': #根据名称(前三个字符)不同分别记入两个列表
boy.append(line_spoken)
if role =='小客服':
girl.append(line_spoken)
#到这一步,所有对话均被存入两列表
else:#不是分割线的情况下,写入
save_file(boy,girl,count) #调用写入,写入后清空列表,等待下次添加对话内容
boy=[]
girl=[]
count+=1 #count从2到3时跳出循环,所以文件里计数器count为3的那一对文件就缺少了
save_file(boy,girl,count)#第三段内容(上方for循环漏掉一次写入)
f.close()
spilt_file('record.txt') 笨鸟学飞 发表于 2020-11-22 19:23
for each_line in f: # 注意看这,这里的each_line是文件的每一行,没一行循环处理保存一次,并不是整个 ...
哦哦,那我明白了,那前面的代码确实可以分出前两段,那后面的代码为什么能分出第三段对话还是有点不理解。。。。。。
file_name_boy = 'boy_' + str(count) + '.txt'
file_name_girl = 'girl_' + str(count) + '.txt'
boy_file = open(file_name_boy, 'w')
girl_file = open(file_name_girl, 'w')
boy_file.writelines(boy)
girl_file.writelines(girl)
昨非 发表于 2020-11-22 19:41
看看这个注释能不能辅助理解
嗯嗯,前面的分段倒是看懂了,就是后面的代码为什么能分出第三段对话还是有点不理解。。。。 珠江东之虎 发表于 2020-11-22 19:50
嗯嗯,前面的分段倒是看懂了,就是后面的代码为什么能分出第三段对话还是有点不理解。。。。
就是for循环的最后一次,只执行了if,将对话存入列表,但是没有写入文件(else没执行),所以需要在后面补上一次 昨非 发表于 2020-11-22 19:59
就是for循环的最后一次,只执行了if,将对话存入列表,但是没有写入文件(else没执行),所以需要在后面 ...
哦哦,懂了,谢了
昨非 发表于 2020-11-22 19:59
就是for循环的最后一次,只执行了if,将对话存入列表,但是没有写入文件(else没执行),所以需要在后面 ...
一语惊醒,非常感谢我纠结这个问题纠结了半个小时
页:
[1]