小甲鱼第31课课后练习

0. pickle的实质是什么?;,c4f
nhjFHy,GKi'@7{BC.#m3&b1sdpx>wA
答:pickle的实质就是利用一些算法将你的数据对象“腌制”成二进制文件,存储在磁盘上,当然也可以放在数据库或者通过网络传输到另一台计算机上。8i6XL=2B
PD=RpL Sye<M{l|]!iF3m_0KnZ
$50gsmJcj%`:[bN) E*-3nS+^}e,67
1. 使用pickle的什么方法存储数据??Kx"L0j;|
d19{OQ<eW0fcG*w68YK'
答:pickle.dump(data, file) # 第一个参数是待存储的数据对象,第二个参数是目标存储的文件对象,注意要先使用'wb'的模式open文件哦^_^"b2^&a
>8+:E3n~VT$u&YW`a!Rj(
6+EB>r8'AP 23:Le9V?k;^yp
2. 使用pickle的什么方法读取数据?<PD#@
dH;!z?luR0yA]V$#vJ1Ncswg
答:pickle.load(file) # 参数是目标存储的文件对象,注意要先使用'rb'的模式open文件哦^_^ j'MXE
o!]kQ4-8uFGjfl"dSJ9h_*nL>3A
QEA>oHeg=&}<9K]_OwUzjiq
3. 使用pickle能不能保存为”*.txt”类型的文件?8G}0A
ow5YtsF|8R`O^,n_!+-N6D4(
答:可以,不过打开后是乱码,因为是以二进制的模式写入的。(例子详见下方动动手第0题)

*split():

split() 方法可以实现将一个字符串按照指定的分隔符切分成多个子串,这些子串会被保存到列表中(不包含分隔符),作为方法的返回值反馈回来。

s.split(sep,maxsplit)

  1. str:表示要进行分割的字符串;
  2. sep:用于指定分隔符,可以包含多个字符。此参数默认为 None,表示所有空字符,包括空格、换行符“ ”、制表符“ ”等。不含参数,以空格进行分割,含参数时,以该参数进行分割。
  3. maxsplit:可选参数,用于指定分割的次数,最后列表中子串的个数最多为 maxsplit+1。如果不指定或者指定为 -1,则表示分割次数没有限制。

4. 编写一个程序,这次要求使用pickle将文件(record.txt)里的对话按照以下要求腌制成不同文件(没错,是第29讲的内容小改,考考你自己能写出来吗?):piQM2$v

    • 小甲鱼的对话单独保存为boy_*.txt的文件(去掉“小甲鱼:”)
    • 小客服的对话单独保存为girl_*.txt的文件(去掉“小客服:”)
    • 文件中总共有三段对话,分别保存为boy_1.txt, girl_1.txt,boy_2.txt, girl_2.txt, boy_3.txt, gril_3.txt共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 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.slipt(":", 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")
      import pickle
      
      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, 'wb') # 记得一定要加 b 吖
          girl_file = open(file_name_girl, 'wb') # 记得一定要加 b 吖
      
          pickle.dump(boy, boy_file)
          pickle.dump(girl, girl_file)
      
          boy_file.close()
          girl_file.close()
      
      def split_file(file_name):
          count = 1
          boy = []
          girl = []
      
          f = open(file_name)
      
          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')
原文地址:https://www.cnblogs.com/celine227/p/13828424.html