python selenium T3
既然要做自动,就得对得起自动化的这个名字。这一章我们将进一步的增加自动化测试的实用,增加
自动发邮件功能、多线程 和定时任务,让我们的自动化工作真正变得高效而又强大起来。
EG1 :
with open('report.html' , 'r') as f: msg = MIMEText(f.read() , _subtype='html' , _charset='utf-8') msg['Subject'] = Header(subject, 'utf-8') msg['date'] = datetime.now().strftime('%Y-%m-%d %H-%M-%S') smtp = smtplib.SMTP() smtp.connect(smtpserver) smtp.login(username, password) smtp.sendmail(sender,receiver , msg.as_string()) smtp.quit()
EG2:
每个进程都有自己的地址空间,内存,数据栈以及其它记录其运行轨迹的辅助数据。操作系统管理在其上运行的所有进程,并为这些进程公平地分配时间。
线程(有时被称为轻量级进程)跟进程有些相似,不同的是,所有的线程运行在同一个进程中,共享
相同的运行环境。我们可以想像成是在主进程或“主线程”中并行运行的“迷你进程”。
在单线程中顺序执行两个循环。一定要一个循环结束后,另一个才能开始。总时间是各个循环
运行时间之和
thread 提供了低级别的、原始的
线程以及一个简单的锁。threading 基于 Java 的线程模型设计。锁(Lock)和条件变量(Condition)
在 Java 中是对象的基本行为(每一个对象都自带了锁和条件变量),而在 Python 中则是独立的对象。
我们应该避免使用 thread 模块,原因是它不支持守护线程。当主线程退出时,所有的子线程不论它
们是否还在工作,都会被强行退出。有时我们并不期望这种行为,这时就引入了守护线程的概念。 threading
模块则支持守护线程。
join()会等到线程结束,或者在给了 timeout 参数的时候,等到超时为止。join()的另一个比较重
要的方面是它可以完全不用调用。一旦线程启动后,就会一直运行,直到线程的函数结束,退出为止。
multiprocessing 使用类似于 threading 模块的 API ,multiprocessing 提供了本地和远程的并发性,有
效的通过全局解释锁(Global Interceptor Lock, GIL)来使用进程(而不是线程)。由于 GIL 的存在,在 CPU 密
集型的程序当中,使用多线程并不能有效地利用多核 CPU 的优势,因为一个解释器在同一时刻只会有一
个线程在执行。所以,multiprocessing 模块可以充分的利用硬件的多处理器来进行工作。它支持 Unix 和
Windows 系统上的运行。
EG1:
from time import sleep, ctime def loop0(): print('start loop 0 at:', ctime()) sleep(1) print('loop 0 done at:', ctime()) def loop1(): print('start loop 1 at:', ctime()) sleep(1) print('loop 1 done at:', ctime()) def main(): print('start:', ctime()) loop0() loop1() print('all end:', ctime()) if __name__ == '__main__': main()
EG2:
import threading from time import sleep from datetime import datetime loops = [2, 4] def loop(nloop , nsec): print('start loop ' , nloop , ' at : ' , datetime.now()) sleep(nsec) print('end loop ' , nloop , ' at : ' , datetime.now()) def main(): print('start main ' , datetime.now()) threads = [] nloops = range(len(loops)) for i in nloops : t = threading.Thread(target=loop , args=(i , loops[i])) threads.append(t) for i in nloops: threads[i].start() # 开启线程 for i in nloops: threads[i].join() # 等待线程终止 print('end main ', datetime.now()) if __name__ == '__main__': main()
EG3:
import threading from time import sleep from datetime import datetime loops = [4, 2] format_date = '%Y-%m-%d-%H-%M-%S' class ThreadFunc(object): def __init__(self, func, args, name): self.name = name self.func = func self.args = args def __call__(self): apply(self.func , self.args) def loop(nloop , nsec): print('start loop ' , nloop , ' at : ' , datetime.now().strftime(format_date)) sleep(nsec) print('end loop ' , nloop , ' at : ' , datetime.now().strftime(format_date)) def main(): print('start main ' , datetime.now()) threads = [] nloops = range(len(loops)) for i in nloops: t = threading.Thread(target=ThreadFunc(loop , (i, loops[i]) , loop.__name__)) threads.append(t) for i in nloops: threads[i].start() for i in nloops: threads[i].join() print('end main ' , datetime.now().strftime(format_date)) if __name__ == '__main__': main()
EG4: