珠江东之虎 发表于 2020-11-22 19:20:08

零基础入门学习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文件里,为什么能形成分段保存的效果?

笨鸟学飞 发表于 2020-11-22 19:23:57

for each_line in f:   # 注意看这,这里的each_line是文件的每一行,没一行循环处理保存一次,并不是整个遍历
    if each_line[:6] != '======':# 这个判断意思是每一行的前6个字符是‘======’

suchocolate 发表于 2020-11-22 19:26:23

自动分

昨非 发表于 2020-11-22 19:41:50

看看这个注释能不能辅助理解
#定义写入函数
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:44:46

笨鸟学飞 发表于 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:50:00

昨非 发表于 2020-11-22 19:41
看看这个注释能不能辅助理解

嗯嗯,前面的分段倒是看懂了,就是后面的代码为什么能分出第三段对话还是有点不理解。。。。

昨非 发表于 2020-11-22 19:59:08

珠江东之虎 发表于 2020-11-22 19:50
嗯嗯,前面的分段倒是看懂了,就是后面的代码为什么能分出第三段对话还是有点不理解。。。。

就是for循环的最后一次,只执行了if,将对话存入列表,但是没有写入文件(else没执行),所以需要在后面补上一次

珠江东之虎 发表于 2020-11-23 20:02:37

昨非 发表于 2020-11-22 19:59
就是for循环的最后一次,只执行了if,将对话存入列表,但是没有写入文件(else没执行),所以需要在后面 ...

哦哦,懂了,谢了

xianziooo 发表于 2020-11-28 23:19:46

昨非 发表于 2020-11-22 19:59
就是for循环的最后一次,只执行了if,将对话存入列表,但是没有写入文件(else没执行),所以需要在后面 ...

一语惊醒,非常感谢我纠结这个问题纠结了半个小时
页: [1]
查看完整版本: 零基础入门学习python的第二十九讲一个任务有些疑问