zoukankan      html  css  js  c++  java
  • python selenium T3

    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:

      

  • 相关阅读:
    feign远程调用问题
    java8--stream
    feign业务组件远程请求 /oauth/token
    redis实现自增序列
    MySQL数据库 相关知识点
    netty
    spring的启动流程及bean的生命周期
    MethodHandleVS反射
    并发与并行
    关于注解的思考
  • 原文地址:https://www.cnblogs.com/zsr0401/p/6489860.html
Copyright © 2011-2022 走看看