第29课文件,一个任务
本帖最后由 子非吾 于 2017-12-27 20:06 编辑这一节课的需要将这个链接: https://pan.baidu.com/s/1hsH6TWo 密码: sczg 将txt文件按如下要求分割存储
f=open('record.txt')
boy=[]
girl=[]
count=1
for each_line in f:
if each_line[:6]!='======':
(role,spoken)=each_line.split(':',1) #split(sep=None,maxsplit=-1)不带默认参数是以空格为字符切片字符串,若maxsplit参数有设置,则仅分割maxsplit个字符串,返回切片后的字符串拼接后的列表。
|
| >>> a='x,aaaaa,bbbb,ccc'
| >>> a.split(',',1)
| ['x', 'aaaaa,bbbb,ccc']
| >>> a.split(',',2)
| ['x', 'aaaaa', 'bbbb,ccc']
| >>> a.split(',',3)
| ['x', 'aaaaa', 'bbbb', 'ccc']
|
if role == '小甲鱼':
boy.append(spoken)
if role == '小客服':
girl.append(spoken)
else: #----------------------------(else: each_line[:6]=='======')。 因为‘======’分隔符有两句,所以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) #----writelines(seq)向文件中写入字符串序列seq,seq应该是一个返回字符串的可迭代对象
girl_file.writelines(girl)
boy_file.close() #close='文件以可写的方式打开就要把写好的文件close(关闭)以保存'
girl_file.close()#close
count+=1#——————————循环一次就加一次1,这样以来girl/boy的1,2文件就出来了
boy=[] #——————————每次都把列表还原,以保证没有上一次循环的内容
girl=[]
#count在这里因为else循环了两次变成了3
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()#close
girl_file.close()#close
f.close()#只读文件也要关闭,这是个好习惯
当然看起来一大坨很不规范,我正在试图通过添加注释的方式来理解程序,大家不要学我。
还能精简成两个函数,已有现成的代码再写出函数很简单,但我现在还不准备把它弄成两个函数。这一节课的知识点不少。
网盘密码没有给我们呀
像番茄加两个蛋 发表于 2017-12-27 18:16
网盘密码没有给我们呀
已修改 子非吾 发表于 2017-12-27 18:41
已修改
非常感谢!请问一下我一模一样和甲老师的代码照打了一遍,为什么我的报错了呀?
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()
本帖最后由 子非吾 于 2017-12-27 21:31 编辑
像番茄加两个蛋 发表于 2017-12-27 19:01
非常感谢!请问一下我一模一样和甲老师的代码照打了一遍,为什么我的报错了呀?
文件第8行出错
没有足够的值取出(分给role和line_spoken)(预期2,得到1)
第8行出错就要看前面if条件语句是不是搞错了
(ps:以上是用网易有道词典瞎猜的!)
问题出在你第7行代码,if each_line[:6] != '=======':这里面多了一个‘=’
str1=长等号分隔符
第7行 代码if each_liens[:6] != ‘=======’语句在遇到str1时,为True。
然后,当第8行代码 (role,lien_spoken) = each_line.spilt(':',1)对str1进行切片操作时,会出错。因为str1里面没有‘:’符号,所以each_line.spilt(':',1)只会返回一个值(一个包含str1的列表)。得到一个值,但是有两个人(role和lien_spoen)来分,报错是理所当然的。
页:
[1]