当我们好不容易获取了一些数据时,想要进行处理的话,通常我们的python小白会选择for循环语句,毕竟这是我们入门时候就接触了的。当然这种方法是可行的,对于没有过多接触python模块的小伙伴们来说已经非常棒了。不过,小编今天推荐大家使用我们最近学习的python爬虫中的多线程进行解决,在时间效率方面非常节约。
第 一步:import threading 模块
import threading
第二步:改下一下代码:
既可以同时打开并运行多个文件
import operator
import csv
import time
import threading
from time import ctime
def read_file(filpos,i):
with open(filpos+str(i)+".csv") as f:
reader=csv.reader(f)
for i in reader:
print(i)
threads = []
x=0
for t in range(0,3):
t= threading.Thread(target=read_file,args=("D:/zhihu/",x))
threads.append(t)
x+=1
#join在里面时候只有第 一个子进程结束才能打开第二个进程,if__name__ 调用时不可用
if __name__=="__main__":
for thr in threads:
thr.start()
thr.join()
print("all over %s"%ctime())
就是把文件添加到线程池里面,再一起执行。
通过以上多线程的代码,我们能比使用for循环节约大量的等待时间,小伙伴们还不心动吗?具体的好处还是需要小伙伴们自己动手才能体会~
上一篇:如何使用pythonmatplotlib库绘制扇形?
下一篇: 没有了
一级建造师二级建造师消防工程师造价工程师土建职称房地产经纪人公路检测工程师建筑八大员注册建筑师二级造价师监理工程师咨询工程师房地产估价师 城乡规划师结构工程师岩土工程师安全工程师设备监理师环境影响评价土地登记代理公路造价师公路监理师化工工程师暖通工程师给排水工程师计量工程师
执业药师执业医师卫生资格考试卫生高级职称护士资格证初级护师主管护师住院医师临床执业医师临床助理医师中医执业医师中医助理医师中西医医师中西医助理口腔执业医师口腔助理医师公共卫生医师公卫助理医师实践技能内科主治医师外科主治医师中医内科主治儿科主治医师妇产科医师西药士/师中药士/师临床检验技师临床医学理论中医理论