国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python實現模擬分割大文件及多線程處理的方法

2020-01-04 16:34:42
字體:
來源:轉載
供稿:網友

本文實例講述了Python實現模擬分割大文件及多線程處理的方法。分享給大家供大家參考,具體如下:

#!/usr/bin/env python#--*-- coding:utf-8 --*--from random import randintfrom time import ctimefrom time import sleepimport queueimport threadingclass MyTask(object):  """具體的任務類"""  def __init__(self, name):    self.name = name    self._work_time = randint(1, 5)  def work(self):    print("Task %s is start : %s, sleep time= %d" % (self.name, ctime(), self._work_time))    sleep(self._work_time)    print("Task %s is end : %s" % (self.name, ctime()))class MyThread(threading.Thread):  """多線程的類"""  def __init__(self, my_queue):    self.my_queue = my_queue    super(MyThread, self).__init__()  def run(self):    while True:      if self.my_queue.qsize() > 0:        self.my_queue.get().work()      else:        breakdef print_split_line(num=30):  print("*" * num)if __name__ == "__main__":  print_split_line()  import my_read_file  # 分割文件  sf = my_read_file.SplitFiles(r"F:/multiple_thread_read_file.txt", line_count=300)  file_num = sf.split_file()  queue_length = file_num  my_queue = queue.LifoQueue(queue_length)  threads = []  for i in range(queue_length):    file_name = sf.get_part_file_name(i)    mt = MyTask(file_name)    my_queue.put_nowait(mt)  for i in range(queue_length):    mtd = MyThread(my_queue)    threads.append(mtd)  for i in range(queue_length):    threads[i].start()  for i in range(queue_length):    threads[i].join()  print_split_line()

 

希望本文所述對大家Python程序設計有所幫助。


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宜川县| 阿城市| 阆中市| 泰兴市| 东阿县| 蚌埠市| 吉林省| 封开县| 宜昌市| 伊吾县| 山东| 淮安市| 项城市| 肥西县| 交城县| 成都市| 都昌县| 上高县| 永德县| 偏关县| 洪江市| 宜黄县| 高台县| 湘西| 平山县| 类乌齐县| 福鼎市| 潮安县| 平阴县| 宁国市| 英超| 离岛区| 鲁甸县| 互助| 巴南区| 图们市| 温泉县| 玉田县| 北宁市| 文成县| 汝州市|