--------------------------第一种: 主线程 和 n个线程 同时启动,主线程执行完了,所有线程都结束
#coding=utf-8
import time
from selenium import webdriver
import threading
def fun1(a):
print a
def fun2():
print 222
threads = []
threads.append(threading.Thread(target=fun1,args=(u'爱情买卖',))) #args为函数接受的参数,多个参数可以传入多个 args=(u'爱情买卖',u'爱情买卖')
threads.append(threading.Thread(target=fun2))
print(threads)
if __name__ == '__main__':
for t in threads:
t.setDaemon(True) #我拿来做selenium自动化模拟多个用户使用浏览器的时候,加了这个就启动不了,要去掉,原因找到了 : 加了这个是说明 主线程 执行完了 子线程也停止(无论是否执行完毕)
t.start()
print "all over %s" %ctime()
代码说明:
import threading
首先导入threading 模块,这是使用多线程的前提。
threads = []
t1 = threading.Thread(target=fun1,args=(u'爱情买卖',))
threads.append(t1)
创建了threads数组,创建线程t1,使用threading.Thread()方法,在这个方法中调用music方法target=music,args方法对music进行传参。 把创建好的线程t1装到threads数组中。
接着以同样的方式创建线程t2,并把t2也装到threads数组。
for t in threads:
t.setDaemon(True) #加了这个 只要 主线程走完了,子线程无论有没执行完 都一起停止。 可以加这个,然后主线程 那里写个判断外部txt文件的值,手动改为1就执行完毕,所有线程都停止了
t.start()
最后通过for循环遍历数组。(数组被装载了t1和t2两个线程)
setDaemon()
setDaemon(True)将线程声明为守护线程,必须在start() 方法调用之前设置,如果不设置为守护线程程序会被无限挂起。子线程启动后,父线程也继续执行下去,当父线程执行完最后一条语句print "all over %s" %ctime()后,没有等待子线程,直接就退出了,同时子线程也一同结束。
start()
开始线程活动。
从执行结果来看,子线程(muisc 、move )和主线程(print "all over %s" %ctime())都是同一时间启动,但由于主线程执行完结束,所以导致子线程也终止。
-----------------------------第二种,要等待所有子线程都执行完毕,主线程才执行完毕 脚本才停止:
if __name__ == '__main__': for t in threads: t.setDaemon(True) t.start() t.join() print "all over %s" %ctime()
我们只对上面的程序加了个join()方法,用于等待线程终止。join()的作用是,在子线程完成运行之前,这个子线程的父线程将一直被阻塞。
注意: join()方法的位置是在for循环外的,也就是说必须等待for循环里的两个进程都结束后,才去执行主进程。
后记:
搞了个并发浏览器操作,
如果要做参数化,用ddt会导致所有行为都在一个浏览器操作,去掉ddt框架后,并发正常 (这里可能是把dirver 定义成全局变量导致的问题!!!!! 去掉后正常)
threading库 知识点补充: https://www.cnblogs.com/kaibindirver/p/12717924.html
参考:
https://www.cnblogs.com/xxswkl/p/11110728.html
https://www.cnblogs.com/fnng/p/3670789.html
虫师那个seleniumpdf里面还有其他方法 可以参考
中文文档: https://docs.python.org/3/library/threading.html?highlight=threading#module-threading
另外一篇 thread 库的https://www.cnblogs.com/kaibindirver/p/12698603.html