使用多线程处理文档的坑

一,问题发现:

使用多线程处理文档时,发现将数据打印在控制台时,任务是并行的,同时执行的
但是将相同的文字写到txt文本时,文本的内容是单线程执行的

1. 下面是代码

#codint=utf-8

from multiprocessing import Process
import time

def run(Str,Num):
    m = 1
    with open("test.txt","a",encoding="utf-8") as FileObj:
        while True:
            FileObj.write("run(%s)方法正在运行,第 %d 次运行,n的值是 %d\n"%(Str,m,Num))
            print("run(%s)方法正在运行,第 %d 次运行,n的值是 %d\n"%(Str,m,Num))
            m += 1
            time.sleep(1)
            if m >= 10:
                break
if __name__ == '__main__':
    with open("test.txt", "a",encoding="utf-8") as FileObj:
        FileObj.write("主进程启动。。。\n")
        print("主进程启动。。。\n")
        # 创建子进程
        # target说明进程执行的任务
        n = 1
        PObj = Process(target=run,args=("nice",n))
        # 启动进程
        PObj.start()
        while True:
            FileObj.write("main()方法正在运行,第 %d 次运行\n"%n)
            print("main()方法正在运行,第 %d 次运行\n"%n)
            n += 1
            time.sleep(1)
            if n >= 10:
                break

2. 控制台打印截图

在这里插入图片描述

3. txt文本截图

在这里插入图片描述

二,问题原因

  1. 出现此问题是因为,打印语句执行完毕后,打印的数据直接输出
  2. 写文件的语句执行完毕后,数据保存在计算机的内存中,等到任务执行完毕,再将内存中的数据统一保存到文件中,将文件关闭,数据才会保存成功。
  3. 因此会出现文本中保存的数据不是并行的

三,解决方法

  1. 每个方法中的写文件的语句执行完后,立即执行一次保存操作,这样调用哪个方法,都会将数据即时保存

四,解决效果

  1. 按照以上方法解决之后,文件中的数据也是并行的了
    在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/zhuan_long/article/details/112213977