文章詳情頁
python - 如何解決queue中同一個參數被多個線程同時調用?
瀏覽:125日期:2022-08-18 15:18:47
問題描述
本人想實現一個基礎的多線程爬蟲,初步想法是篩選目錄中多個電影標題是否有關鍵字,沒有的話就進入到詳情頁中查找電影類別中是否有關鍵字。下面是一部分代碼:
executor = ThreadPoolExecutor(max_workers=5) #Future模塊的多線程executor.map(get_page,whole) #get_page()為篩選標題的函數time.sleep(5)while not que.empty(): que_data = que.get() filter(que_data) #filter()為篩選分類關鍵字的函數,但每次五個線程同時訪問同一個url
但現在每次多個線程同時調用queue中的同一個url,請問有什么解決辦法嗎
問題解答
回答1:專門用一個線程讀取queue中的url,然后分配給某個線程
對該queue的訪問加鎖
相關文章:
1. nignx - docker內nginx 80端口被占用2. java - SSH框架中寫分頁時service層中不能注入分頁類3. docker-machine添加一個已有的docker主機問題4. python3.x - python連oanda的模擬交易api獲取json問題第五問5. docker鏡像push報錯6. angular.js - angular內容過長展開收起效果7. node.js - 我是一個做前端的,求教如何學習vue,node等js引擎?8. debian - docker依賴的aufs-tools源碼哪里可以找到啊?9. html5 - 百度echart官網下載的地圖json數據亂碼10. 關于docker下的nginx壓力測試
排行榜
