该题split()方法用法
def split_file(file_name):f = open(file_name)
boy = []
girl = []
count = 1
for each_line in f:
if each_line[:6] != "======":
(role,spoken) = each_line.split(":"1) #这里的maxsplit参数不设置为1,按默认来说,for循环每一次不也是一个子字符串嘛?那这么设置的意义是什么?默认的话还会出错,显示太多值无法解包
if role == "小甲鱼":
boy.append(spoken)
if role == "小客服":
girl.append(spoken)
else:
save_file(boy,girl,count)
boy = []
girl = []
count += 1
save_file(boy,girl,count)
f.close()
def save_file(boy,girl,count):
file_name_boy = "boy_"+str(count) + ".txt"
file_name_girl = "girl_"+str(count) + ".txt"
file_boy =open(file_name_boy,"w")
file_girl = open(file_name_girl,"w")
file_boy.writelines(boy)
file_girl.writelines(girl)
file_boy.close()
file_girl.close()
split_file("record2.txt")
#处为问题
应该是怕人说的话中还有 冒号 吧~,(我猜) 比如
小甲鱼:blablabla:blabla
如果不加 1 就会被分割成
["小甲鱼", "blablabla", "blabla"]
如果加 1 就会分割成
["小甲鱼", "blablabla:blabla"] 本帖最后由 Twilight6 于 2020-5-24 13:05 编辑
按默认来说,for循环每一次不也是一个子字符串嘛?
不是,这里是 for 是遍历文件 f的每一行,每次循环是以行为单位遍历的,一整行、一整行的拿来for循环的
那这么设置的意义是什么?
设置 1 的意思是只切割一次 防止人说话中带 冒号就会切割出大于 2 个 的值
因为你只设置两个参数接受 切割后的值,所以会报错
而且你的代码错了 少了个逗号
each_line.split(":",1)
支持楼上 Twilight6 发表于 2020-5-24 13:03
不是,这里是 for 是遍历文件 f的每一行,每次循环是以行为单位遍历的,一整行、一整行的拿来for循环的 ...
听了你的才把这个意思理解正确感谢 莫待无花空折枝 发表于 2020-5-24 13:23
听了你的才把这个意思理解正确感谢
嘿嘿~能帮助到你就好~{:10_287:}
页:
[1]