Arcticfoxer 发表于 2020-12-2 16:05:20

29讲,关于文件、for循环问题

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()
以上是小甲鱼29讲的内容,我不太理解的是,for each_line in f:,这个each_line怎么就是以每行字符串为单位去遍历for循环了?不是应该以每个字符为单位么?

昨非 发表于 2020-12-2 16:11:48

一行行读的

Arcticfoxer 发表于 2020-12-2 16:15:23

昨非 发表于 2020-12-2 16:11
一行行读的

为啥不是一个个读的,之前学的都是一个个字符读的

昨非 发表于 2020-12-2 16:25:01

Arcticfoxer 发表于 2020-12-2 16:15
为啥不是一个个读的,之前学的都是一个个字符读的

只读的时候
for循环遍历文件都是一行行读的
如果你遍历打印出来的东西是一个字符一个字符的,那么你文件里应该也是每行一个字符存储的

昨非 发表于 2020-12-2 16:27:08

Arcticfoxer 发表于 2020-12-2 16:15
为啥不是一个个读的,之前学的都是一个个字符读的

大可自己随便建个txt文件试试读取写入的语法规则

Arcticfoxer 发表于 2020-12-2 21:01:43

本帖最后由 Arcticfoxer 于 2020-12-2 21:12 编辑

1

Arcticfoxer 发表于 2020-12-2 21:04:30

昨非 发表于 2020-12-2 16:27
大可自己随便建个txt文件试试读取写入的语法规则

>>> n = open('D:/test.txt')
>>> p = n.read()
>>> for m in p:
      if len(m) == 8:
                print(m)

               
>>> p
'jsuejhzh\njieshncf\njaiodjfaiweo\nasdf\nmxhgncif\niwiwiwiw\naafh'
>>> m
'h'
>>>
不行啊大哥,还是一个个读的

昨非 发表于 2020-12-2 21:07:01

Arcticfoxer 发表于 2020-12-2 21:04
不行啊大哥,还是一个个读的

#定义写入函数
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 spilt_file(file_name): #传入文件名
      f = open(file_name,"r",encoding='UTF-8')
         #关键点,编码方式                   就这里换个编码形式
      boy=[]   
      girl=[]
      count=1   
            
      for each_line in f: #遍历原对话文件每一行
            if each_line[:6]!='======':#以分割线判断
                (role,line_spoken)=each_line.split(':',1)
                #以:为界,分成元组,进行1次操作
                if role =='小甲鱼': #根据名称(前三个字符)不同分别记入两个列表
                  boy.append(line_spoken)
                if role =='小客服':
                  girl.append(line_spoken)
                  #到这一步,所有对话均被存入两列表
            else:#不是分割线的情况下,写入
                save_file(boy,girl,count) #调用写入,写入后清空列表,等待下次添加对话内容
               
                boy=[]
                girl=[]
                count+=1   #count从2到3时跳出循环,所以文件里计数器count为3的那一对文件就缺少了
            
      save_file(boy,girl,count)#第三段内容(上方for循环漏掉一次写入)
      f.close()   
      
   
   
spilt_file('record.txt')   

record.txt
小客服:小甲鱼,今天有客户问你有没有女朋友?
小甲鱼:咦??
小客服:我跟她说你有女朋友了!
小甲鱼:。。。。。
小客服:她让你分手后考虑下她!然后我说“。。”
小甲鱼:然后呢?
小客服:她。。。。
小甲鱼:呃。。。你真牛逼!
小客服:那是,。。。
小甲鱼:下次有人想调戏你,我不阻止
小客服:滚!!
===========================================================================
小客服:小甲鱼,有个好评很好笑
小甲鱼:哦?
小客服:“有了小甲鱼,妈妈再也。。。。”
小甲鱼:哈哈哈,看到了,我还发了微博呢~
小客服:我看了你的微博呀!
小甲鱼:哟西~
小客服:那个回复“。。。。。。”
小甲鱼:T_T
============================================================================
小客服:小甲鱼,今天一个会员想找你
小甲鱼:哦?什么事儿?
小客服:他说你的一个学生月薪已经超过12k了
小甲鱼:哪里的?
小客服:上海的
小甲鱼:那正常,哪家公司的?
小客服:没说啊
小甲鱼:哦
小客服:老大,为什么我工资那么低啊,是时候涨工资了!!
小甲鱼:啊?你说什么?外面风大,听不见啊~~~~
小客服:滚!!!
页: [1]
查看完整版本: 29讲,关于文件、for循环问题