如下所示:
#統計某文件夾下的所有csv文件的行數(多線程)import threadingimport csvimport os class MyThreadLine(threading.Thread): #用于統計csv文件的行數的線程類 def __init__(self,path): threading.Thread.__init__(self) #父類初始化 self.path=path #路徑 self.line=-1 #統計行數 def run(self): reader = csv.reader(open(self.path, "r")) # 讀取csv文件 lines=0 for item in reader: # 讀取每一行 lines+=1 self.line=lines #保存行數 print(self.getName(),self.line) path="C:/Users/aa/csv" #所有csv文件所在的文件夾filelist=os.listdir(path) #存儲了所有的csv文件名threadlist=[] #線程列表for filename in filelist: newpath=path+"/"+filename #代表絕對路徑 mythd=MyThreadLine( newpath) #創建線程類對象 mythd.start() #線程開始干活 threadlist.append(mythd) #增加線程到線程列表for mythd in threadlist: #遍歷每一個線程 mythd.join() #等待所有線程干完活,再繼續執行以下代碼linelist=[] #csv文件行數列表for mythd in threadlist: linelist.append(mythd.line)print(linelist)
以上這篇對Python 多線程統計所有csv文件的行數方法詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林站長站。
新聞熱點
疑難解答