python修煉day32!
今日內(nèi)容概述:
多進(jìn)程實(shí)現(xiàn)文件夾下載、迭代器、生成器、協(xié)程
昨日回顧
程序:一個(gè)靜態(tài)的概念
進(jìn)程:一個(gè)動(dòng)態(tài)的概念,就是程序運(yùn)行起來(lái)的狀態(tài),用于一定的資源
線程:運(yùn)行在進(jìn)程之內(nèi),依賴于進(jìn)程,
進(jìn)程和線程區(qū)別:
共同點(diǎn):都可以完成多任務(wù)區(qū)別: 線程: threading 依賴于進(jìn)程 多線程之間共享全局的變量 主線程等待子線程結(jié)束,才結(jié)束 系統(tǒng)開(kāi)銷較小 進(jìn)程: multiprocessing 運(yùn)行起來(lái)的應(yīng)用程序,占有一些資源 寫(xiě)時(shí)拷貝,進(jìn)程不共享全局的資源 通過(guò)隊(duì)列實(shí)現(xiàn)進(jìn)程間通信 系統(tǒng)開(kāi)銷比較大
進(jìn)程的創(chuàng)建:
multiprocessing.Process(target=函數(shù)名,args=(參數(shù)))繼承方式創(chuàng)建進(jìn)程class 子類名(multiprocessing.Proces): def run(self): pass
進(jìn)程間通信(傳遞數(shù)據(jù) ):
q = multiprocessing.Queue(3) # 創(chuàng)建一個(gè)隊(duì)列,可以指定可傳遞幾個(gè)數(shù)據(jù)q.put () # 存 q.get() # 取 q.qsize() # 取消息數(shù)量 q.full() # 判斷是否滿了q.empty # 判斷是否為空
進(jìn)程池:
一個(gè)特殊的容器,里面創(chuàng)建了很多進(jìn)程,重復(fù)利用進(jìn)程作用:減少了創(chuàng)建,銷毀進(jìn)程的過(guò)程,提高了效率po = multiprocessing.Pool(3) # 定義一個(gè)進(jìn)程池,最大進(jìn)程數(shù)2po.a(chǎn)pply_async(要調(diào)用的目標(biāo),(要傳遞的參數(shù))) # async 異步po.close() # 關(guān)閉進(jìn)程池po.join() # 等待所有的子進(jìn)程執(zhí)行完畢
今日內(nèi)容
文件夾復(fù)制:
os.listdir() # 列出文件夾中所有的文件名os.path.getsize() # 獲取文件的大小os.mkdir() # 新建文件夾Pool() # 創(chuàng)建進(jìn)程池Manger().Queue() # 有進(jìn)程池的時(shí)候,隊(duì)列需要 Manger()中的Queue() with open("文件名", “rw”) as f: f.read() # 讀 f.write() # 寫(xiě)
文件夾復(fù)制代碼
import multiprocessing
import os, time
def save_folder(q, dw_folder_name, save_folder_name, file_name):
with open(dw_folder_name + "/" + file_name, "rb") as f:
content = f.read()
# 在新創(chuàng)建的文件中寫(xiě)入文件
with open(save_folder_name + "/" + file_name, "wb") as f2:
f2.write(content)
new_file_size = os.path.getsize(save_folder_name + "/" + file_name)
q.put(new_file_size)
def main():
# 提示用戶輸入文件夾名
dw_folder_name = input("請(qǐng)輸入要下載的文件夾的名字:")
try:
# 創(chuàng)建一個(gè)新文件夾
save_folder_name = dw_folder_name + "[嘿嘿嘿]"
os.mkdir(save_folder_name)
except:
pass
# 獲取目標(biāo)文件夾中的所有的文件 os.listdir()
file_names = os.listdir(dw_folder_name)
# 添加進(jìn)程池
po = multiprocessing.Pool(3)
# 創(chuàng)建隊(duì)列
q = multiprocessing.Manager().Queue()
# 從目標(biāo)文件夾中讀取文件
for file_name in file_names:
po.a(chǎn)pply_async(save_folder, (q, dw_folder_name, save_folder_name, file_name))
po.close()
# po.join()
# 獲取文件夾的大小
folder_size = 0
for old_file in file_names:
old_file_s = os.path.getsize(dw_folder_name + "/" + old_file)
folder_size += old_file_s
print("文件夾總大小為: %d" % folder_size)
new_file_size = 0
# 顯示進(jìn)度
while True:
s = q.get()
new_file_size += s
time.sleep(0.1)
print("拷貝的進(jìn)度為: %.2f %%" % (new_file_size / folder_size * 100), end="")
if new_file_size >= folder_size:
break
print()
if __name__ == "__main__":
main()
進(jìn)程池中的進(jìn)程出現(xiàn)異常不會(huì)顯示
發(fā)表評(píng)論
請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字
最新活動(dòng)更多
-
10月31日立即下載>> 【限時(shí)免費(fèi)下載】TE暖通空調(diào)系統(tǒng)高效可靠的組件解決方案
-
即日-11.13立即報(bào)名>>> 【在線會(huì)議】多物理場(chǎng)仿真助跑新能源汽車
-
11月28日立即報(bào)名>>> 2024工程師系列—工業(yè)電子技術(shù)在線會(huì)議
-
12月19日立即報(bào)名>> 【線下會(huì)議】OFweek 2024(第九屆)物聯(lián)網(wǎng)產(chǎn)業(yè)大會(huì)
-
即日-12.26火熱報(bào)名中>> OFweek2024中國(guó)智造CIO在線峰會(huì)
-
即日-2025.8.1立即下載>> 《2024智能制造產(chǎn)業(yè)高端化、智能化、綠色化發(fā)展藍(lán)皮書(shū)》
推薦專題
- 1 【一周車話】沒(méi)有方向盤(pán)和踏板的車,你敢坐嗎?
- 2 特斯拉發(fā)布無(wú)人駕駛車,還未迎來(lái)“Chatgpt時(shí)刻”
- 3 特斯拉股價(jià)大跌15%:Robotaxi離落地還差一個(gè)蘿卜快跑
- 4 馬斯克給的“驚喜”夠嗎?
- 5 打完“價(jià)格戰(zhàn)”,大模型還要比什么?
- 6 馬斯克致敬“國(guó)產(chǎn)蘿卜”?
- 7 神經(jīng)網(wǎng)絡(luò),誰(shuí)是盈利最強(qiáng)企業(yè)?
- 8 比蘋(píng)果偉大100倍!真正改寫(xiě)人類歷史的智能產(chǎn)品降臨
- 9 諾獎(jiǎng)進(jìn)入“AI時(shí)代”,人類何去何從?
- 10 Open AI融資后成萬(wàn)億獨(dú)角獸,AI人才之爭(zhēng)開(kāi)啟
- 高級(jí)軟件工程師 廣東省/深圳市
- 自動(dòng)化高級(jí)工程師 廣東省/深圳市
- 光器件研發(fā)工程師 福建省/福州市
- 銷售總監(jiān)(光器件) 北京市/海淀區(qū)
- 激光器高級(jí)銷售經(jīng)理 上海市/虹口區(qū)
- 光器件物理工程師 北京市/海淀區(qū)
- 激光研發(fā)工程師 北京市/昌平區(qū)
- 技術(shù)專家 廣東省/江門(mén)市
- 封裝工程師 北京市/海淀區(qū)
- 結(jié)構(gòu)工程師 廣東省/深圳市