class Thread:
def __init__(self, group=None, target=None, name=None,
args=(), kwargs=None, *, daemon=None):
pass
# Thread类是python用来创建线程的类,
group:扩展保留字段;
target:目标代码,一般是我们需要创建线程执行的目标函数。
name:线程的名字,如果不指定会自动分配一个;
args:目标函数的普通参数;
kwargs:目标函数的键值对参数;
daemon:设置线程是否为守护线程,即是前台执行还是后台执行,默认是非守护线程,当daemon=True时,子线程为守护线程,此时主线程不会等待子线程,如果主线程完成会强制杀死所有的子线程然后退出。
# 方法
start():创建一个子线程并执行,该方法一个Thread实例只能执行一次,其会创建一个线程执行该类的run方法。
run():子线程需要执行的代码;
join():主线程阻塞等待子线程直到子线程结束才继续执行,可以设置等待超时时间timeout.
ident():线程标识符,线程未启动之前为None,启动后为一个int;
is_alive():查看子线程是否还活着你返回一个布尔值。
daemon:判断是否是守护线程;
import threading
import time
def test():
for i in range(10):
print("test is run:", i)
time.sleep(1)
if __name__ == '__main__':
# 创建子线程
t1 = threading.Thread(target=test)
t1.setDaemon(True) #设置t1(test函数)为守护线程,当主线程结束了,也随之结束
# 启动子线程
t1.start()
# 休眠2秒
time.sleep(2)
# join方法主要是会阻塞主线程,在子线程结束运行前,主线程会被阻塞等待
# join 等待,t1.jion 就是必须等t1运行完成后,在接着运行后面的代码
#t1.join()
print("我 OVER 了")
# 退出
#exit()
t1.jion 就是必须等子线程t1运行完成后,在接着运行后面的代码
多线程执行测试用例
# 多线程执行测试用例
from threading import Thread
from selenium import webdriver
from time import ctime, sleep
# 测试用例
def test_baidu(browser, search):
print('start:%s' % ctime())
print('browser:%s ,' % browser)
if browser == "chrome":
driver = webdriver.Chrome()
elif browser == "ie":
driver = webdriver.Ie()
elif browser == 'ff':
driver=webdriver.Firefox()
else:
print('browser参数有误,只能为ff、chrome')
driver.get('http://www.baidu.com')
driver.find_element_by_id("kw").send_keys(search)
driver.find_element_by_id('su').click()
sleep(2)
driver.quit()
if __name__ == "__main__":
# 启动参数(指浏览器与百度搜索内容)
lists = {'chrome': 'threading', 'ie': 'python','ff':'firefox'}
threads = []
files = range(len(lists))
# 创建子线程
for browser, search in lists.items():
t = Thread(target=test_baidu, args=(browser, search))
threads.append(t)
# 启动线程
for t in files:
threads[t].start()
for t in files:
threads[t].join() # join()函数必须放在线程启动之后
print('end:%s' % ctime())