鱼C论坛

 找回密码
 立即注册
查看: 603|回复: 3

[已解决]python永久储存课后作业

[复制链接]
发表于 2020-4-8 19:23:35 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
我的代码:
  1. import pickle

  2. def dump(count,boy,girl):
  3.     open('boy_'+count+'.txt')
  4.     open('girl_'+count+'.txt')
  5.     pickle.dump(boy,'boy_'+count+'.txt')
  6.     pickle.dump(girl,'girl_'+count+'.txt')
  7.     'boy_'+count+'.txt'.close()
  8.     'girl_'+count+'.txt'.close()

  9. def split(file):
  10.     count = 1
  11.     boy = []
  12.     girl = []

  13.     for each in file:
  14.         if '====' not in each:
  15.             (name,spoken) = each.split(':',1)
  16.             if name == '小甲鱼':
  17.                 boy.append(spoken)
  18.             elif name == '小客服':
  19.                 girl.append(spoken)
  20.         else:
  21.             dump(count,boy,girl)
  22.             boy = []
  23.             girl = []

  24.     dump(count,boy,girl)
  25.     file.close()

  26. file = open('record.txt','r',encoding='utf-8')
  27. split(file)
复制代码

报错代码:
  1. Traceback (most recent call last):
  2.   File "D:/编程练习/课后作业(永久储存,第31讲,动动手第0题).py", line 32, in <module>
  3.     split(file)
  4.   File "D:/编程练习/课后作业(永久储存,第31讲,动动手第0题).py", line 16, in split
  5.     for each in file:
  6.   File "C:\Users\Administrator\AppData\Local\Programs\Python\Python38-32\lib\codecs.py", line 322, in decode
  7.     (result, consumed) = self._buffer_decode(data, self.errors, final)
  8. UnicodeDecodeError: 'utf-8' codec can't decode byte 0xbf in position 2: invalid start byte
复制代码

最佳答案
2020-4-8 19:31:22
  1. import pickle

  2. def save_file(boy, girl, count):
  3.     file_name_boy = 'boy_' + str(count) + '.txt'
  4.     file_name_girl = 'girl_' + str(count) + '.txt'

  5.     boy_file = open(file_name_boy, 'wb') # 记得一定要加 b 吖
  6.     girl_file = open(file_name_girl, 'wb') # 记得一定要加 b 吖

  7.     pickle.dump(boy, boy_file)
  8.     pickle.dump(girl, girl_file)

  9.     boy_file.close()
  10.     girl_file.close()

  11. def split_file(file_name):
  12.     count = 1
  13.     boy = []
  14.     girl = []

  15.     f = open(file_name)

  16.     for each_line in f:
  17.         if each_line[:6] != '======':
  18.             (role, line_spoken) = each_line.split(':', 1)
  19.             if role == '小甲鱼':
  20.                 boy.append(line_spoken)
  21.             if role == '小客服':
  22.                 girl.append(line_spoken)
  23.         else:
  24.             save_file(boy, girl, count)

  25.             boy = []
  26.             girl = []
  27.             count += 1

  28.     save_file(boy, girl, count)
  29.     f.close()

  30. split_file('record.txt')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-4-8 19:31:22 | 显示全部楼层    本楼为最佳答案   
  1. import pickle

  2. def save_file(boy, girl, count):
  3.     file_name_boy = 'boy_' + str(count) + '.txt'
  4.     file_name_girl = 'girl_' + str(count) + '.txt'

  5.     boy_file = open(file_name_boy, 'wb') # 记得一定要加 b 吖
  6.     girl_file = open(file_name_girl, 'wb') # 记得一定要加 b 吖

  7.     pickle.dump(boy, boy_file)
  8.     pickle.dump(girl, girl_file)

  9.     boy_file.close()
  10.     girl_file.close()

  11. def split_file(file_name):
  12.     count = 1
  13.     boy = []
  14.     girl = []

  15.     f = open(file_name)

  16.     for each_line in f:
  17.         if each_line[:6] != '======':
  18.             (role, line_spoken) = each_line.split(':', 1)
  19.             if role == '小甲鱼':
  20.                 boy.append(line_spoken)
  21.             if role == '小客服':
  22.                 girl.append(line_spoken)
  23.         else:
  24.             save_file(boy, girl, count)

  25.             boy = []
  26.             girl = []
  27.             count += 1

  28.     save_file(boy, girl, count)
  29.     f.close()

  30. split_file('record.txt')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-8 19:32:50 | 显示全部楼层
回顾了以下视频,修改了一些小问题。
  1. import pickle

  2. def dump(count,boy,girl):
  3.     boy_file = open('boy_'+count+'.txt','w',encoding='utf-8')
  4.     girl_file = open('girl_'+count+'.txt','w',encoding='utf-8')
  5.     pickle.dump(boy,boy_file)
  6.     pickle.dump(girl,girl_file)
  7.     'boy_'+count+'.txt'.close()
  8.     'girl_'+count+'.txt'.close()
  9.     count += 1

  10. def split(file):
  11.     count = 1
  12.     boy = []
  13.     girl = []

  14.     for each in file:
  15.         if '====' not in each:
  16.             (name,spoken) = each.split(':',1)
  17.             if name == '小甲鱼':
  18.                 boy.append(spoken)
  19.             elif name == '小客服':
  20.                 girl.append(spoken)
  21.         else:
  22.             dump(count,boy,girl)
  23.             boy = []
  24.             girl = []

  25.     dump(count,boy,girl)
  26.     file.close()

  27. file = open('record.txt','r',encoding='utf-8')
  28. split(file)
复制代码

报错代码:
  1. Traceback (most recent call last):
  2.   File "D:/编程练习/课后作业(永久储存,第31讲,动动手第0题).py", line 33, in <module>
  3.     split(file)
  4.   File "D:/编程练习/课后作业(永久储存,第31讲,动动手第0题).py", line 17, in split
  5.     for each in file:
  6.   File "C:\Users\Administrator\AppData\Local\Programs\Python\Python38-32\lib\codecs.py", line 322, in decode
  7.     (result, consumed) = self._buffer_decode(data, self.errors, final)
  8. UnicodeDecodeError: 'utf-8' codec can't decode byte 0xbf in position 2: invalid start byte
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-8 19:41:41 | 显示全部楼层
hhjdsd 发表于 2020-4-8 19:32
回顾了以下视频,修改了一些小问题。

报错代码:

不要用 utf-8 试试
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-22 07:36

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表