|  | 
 
| 
本帖最后由 不吃洋葱 于 2020-9-18 19:45 编辑
x
马上注册,结交更多好友,享用更多功能^_^您需要 登录 才可以下载或查看,没有账号?立即注册  
 求助各位大神,下面的代码哪里出错了
  一直报错。 Traceback (most recent call last):
 File "F:\文件\mine\Study\编程\python\《零基础入门学习Python》-小甲鱼\课后作业\课后练习代码\test_1.py", line 42, in <module>
 split_file('record.txt')
 File "F:\文件\mine\Study\编程\python\《零基础入门学习Python》-小甲鱼\课后作业\课后练习代码\test_1.py", line 24, in split_file
 for each_line in f:
 UnicodeDecodeError: 'gbk' codec can't decode byte 0xae in position 4: illegal multibyte sequence
 
 代码:
 #将文件(record.txt)中的数据进行分割并按照以下规律进行保存
 #1)将小甲鱼的话单独保存为boy_*.txt的文件(去掉“小甲鱼:”)
 #2)将小客服的话单独保存为girl_*.txt的文件(去掉“小客服:”)
 #3)文件中总共有三段话,每段换单独保存为一个文件,且分别为boy_1.txt,boy_2.txt,boy_3.txt;girl_1.txt,girl_2.txt,girl_3.txt
 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 split_file(file_name):
 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:
 save_file(boy,girl,count)
 boy = []
 girl = []
 count += 1
 
 save_file(boy,girl,count)
 
 f.close()
 
 split_file('record.txt')
 
复制代码#定义写入函数
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
            
        save_file(boy,girl,count)  #第三段内容(上方for循环漏掉一次写入)
        f.close()    
        
    
    
spilt_file('record.txt')   
    
    
 | 
 |