python多進程實現(xiàn)數(shù)據(jù)共享的示例代碼
背景
安卓ui自動化框架,使用的是多進程實現(xiàn)的多設(shè)備并行。而在撈取數(shù)據(jù)做數(shù)據(jù)匯總時,需要多進程可以數(shù)據(jù)共享。
進程、進程創(chuàng)建
程序編寫完沒有運行稱之為程序。正在運行的代碼就是進程。在Python3語言中,對多進程支持的是multiprocessing模塊和subprocess模塊。multiprocessing模塊為在子進程中運行任務(wù)、通訊和共享數(shù)據(jù),以及執(zhí)行各種形式的同步提供支持。
Python提供了非常好用的多進程包multiprocessing,只需要定義一個函數(shù),Python會完成其他所有事情。借助這個包,可以輕松完成從單進程到并發(fā)執(zhí)行的轉(zhuǎn)換。multiprocessing支持子進程、通信和共享數(shù)據(jù)。語法格式如下:
Process([group [, target [, name [, args [, kwargs]]]]])
進程間通信
多線程:共享變量很簡單,直接定義全局 global 變量即可
多進程:全局變量在多個進程中不共享,進程之間的數(shù)據(jù)是獨立的,默認情況下互不影響。
from multiprocessing import Process num=1 def work1(): global num num+=5 print('子進程1運行,num:',num) def work2(): global num num += 10 print('子進程2運行,num:',num) if __name__=='__main__': print('父進程開始運行') p1=Process(target=work1) p2=Process(target=work2) p1.start() p2.start() p1.join() p2.join()
執(zhí)行結(jié)果
父進程開始運行
子進程1運行,num:6
子進程2運行,num:11
- 但是python也提供了這樣的標準庫。process進程的manager模塊和pool進程的manager模塊。
進程間共享數(shù)據(jù)
- 共享數(shù)值型數(shù)據(jù)
主進程與子進程共用一個value
import multiprocessing def func(num): num.value = 2 if __name__ == "__main__": num = multiprocessing.Value("d", 1) p = multiprocessing.Process(target=func, args=(num,)) p.start() p.join()
- 共享數(shù)組型數(shù)據(jù)
子進程改變dict,list,主進程dict,list跟著改變
共享list實踐
現(xiàn)在想把每個手機的自動化運行結(jié)果的元組拿出來分析,使用共享list的方式
# 多進程中,同一個變量,各自有一份拷貝存在于每個進程中, 互不影響; # 多線程中,所有變量都由所有線程共享,任何一個變量都可以被任何一個線程修改. # multiprocessing.Manager()實現(xiàn)多進程中的數(shù)據(jù)共享 RESULT_TIMEPARAM = multiprocessing.Manager().list() RESULT_REPORT_NAME_LIST = multiprocessing.Manager().list() RESULT_TUPLE_LIST = multiprocessing.Manager().list() devices_pool = [] for tmp_udid in ConfigData().mobile_data().keys(): devices_pool.append(multiprocessing.Process(target=run_testcase, args=(tmp_udid,RESULT_TIMEPARAM,RESULT_REPORT_NAME_LIST, RESULT_TUPLE_LIST ))) for devices_udid in devices_pool: devices_udid.start() for devices_udid in devices_pool: devices_udid.join()
得到的RESULT_TUPLE_LIST:
[('2022-10-11 09:59:46', '共 1,通過 1,通過率= 100.00%', 'Android', '7.1.2', 'samsung', '3.9.3.018'), ('2022-10-11 09:59:47', '共 1,通過 1,通過率= 100.00%', 'Android', '10', 'OPPO', '3.9.3.018')]
到此這篇關(guān)于python多進程實現(xiàn)數(shù)據(jù)共享的示例代碼的文章就介紹到這了,更多相關(guān)python多進程數(shù)據(jù)共享內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python實現(xiàn)在PyPI上發(fā)布自定義軟件包的方法詳解
在Python中我們經(jīng)常使用pip來安裝第三方Python軟件包,其實我們每個人都可以免費地將自己寫的Python包發(fā)布到PyPI上。本文我們就將詳細介紹如何發(fā)布測試包,需要的可以參考一下2022-06-06tensorflow保持每次訓(xùn)練結(jié)果一致的簡單實現(xiàn)
今天小編就為大家分享一篇tensorflow保持每次訓(xùn)練結(jié)果一致的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-02-02python中將正則過濾的內(nèi)容輸出寫入到文件中的實例
今天小編就為大家分享一篇python中將正則過濾的內(nèi)容輸出寫入到文件中的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10用Python的pandas框架操作Excel文件中的數(shù)據(jù)教程
這篇文章主要介紹了用Python的pandas框架操作Excel文件中的數(shù)據(jù)教程,包括單位格式轉(zhuǎn)換、分類匯總等基本操作,需要的朋友可以參考下2015-03-03Python使用matplotlib實現(xiàn)交換式圖形顯示功能示例
這篇文章主要介紹了Python使用matplotlib實現(xiàn)交換式圖形顯示功能,結(jié)合實例形式詳細分析了Python基于matplotlib模塊的數(shù)值運算與圖形繪制相關(guān)操作技巧,需要的朋友可以參考下2019-09-09