|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
def file_name(boy,girl,count):
file_name_boy = 'D:\\Work\\python\\doc\\boy_' + str(count) + '.txt'
file_name_girl = 'D:\\Work\\python\\doc\\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(filename):
f = open(filename)
boy = []
girl = []
count = 1
for each in f:
if each[:6] != '======'
role,word= each.split(':',1) #此处split的参数为啥非要带上1呢,
if role =='小甲鱼':
boy.append(word)
if role =='小客服':
girl.append(word)
else:
file_name(boy,girl,count)
boy = []
girl = []
count += 1
file_name(boy,girl,count)
f.close()
split_file('D:\\Work\\record.txt')
for循环每次取一行,而每一行都只有一个‘:’作为分割,那么这个1就感觉没那么必要写了
但如果不加上分割次数1,又要报错,求助大佬!!!
本帖最后由 Twilight6 于 2020-6-9 07:57 编辑
for循环每次取一行,而每一行都只有一个‘:’作为分割,那么这个1就感觉没那么必要写了
但如果不加上分割次数1,又要报错,求助大佬!!!
实际上,对于小甲鱼的文本,你如果只写:role,word= each.split(':')
是不会报错的,因为小甲鱼文本中,每一行都只有一个冒号,而你会报错的原因是你 if 那少了个冒号吧...
或者你的文本有改动,又或者文本是自己拼的部分冒号打成了中文
假设文件中有一句话是这样的,才会导致报错:
这一行有两个冒号,导致 split 切割冒号时候出现 三个部分 即切割后为: ['小甲鱼说','你为什么说','我是猪?\n']
而你这代码只用 role , word 来接受切割后的两个值2,所以还有一个值不知道该何去何从,导致报错
所以你填写 split 第二个参数 就是切割次数,填写只切割一次,就避免了人说话中带有冒号
record.txt 完整内容:小客服:小甲鱼,今天有客户问你有没有女朋友?
小甲鱼:咦? ?
小客服:我跟她说你有女朋友了!
小客服:她让你分手后考虑下她!然后我说: "您要买个优盘,我就帮您留意下~"
小甲鱼:然后呢?
小客服:她买了两个,说发一个货就好~
小甲鱼:呃。。。。。。你真牛!
小客服:那是,谁让我是鱼C最可爱小客服嘛~
小甲鱼:下次有人想调戏你我不阻止~
小客服:滚! ! !
================================================================================
小客服:小甲鱼,有个好评很好笑哈。
小甲鱼:哦?
小客服:"有了小甲鱼,以后妈妈再也不用担心我的学习了~”
小甲鱼:哈哈哈, 我看到丫A我还发微博了呢~
小客服:嗯嗯,我看了你的微博丫~
小甲鱼:哟西~
小客服:那个有条回复"左手拿著小甲魚,右手拿著打火機,哪裡不會點哪裡, so easy^. ^”
小甲鱼:T_T
================================================================================
小客服:小甲鱼,今天- -个会员想找你
小甲鱼:哦?什么事?
小客服:他说你- -个学生月薪已经超过12k了! !
小甲鱼:哪里的?
小客服:上海的
小甲鱼:那正常,哪家公司?
小客服:他没说呀。
小甲鱼:哦
小客服:老大,为什么我工资那么低啊? ?是时候涨涨工资了! !
小甲鱼:啊,你说什么?我在外边呢,这里好吵吖。。。。。。
小客服:滚! ! !
|
|