當前位置: 首頁>>代碼示例>>Python>>正文


Python queue.Queue方法代碼示例

本文整理匯總了Python中queue.Queue方法的典型用法代碼示例。如果您正苦於以下問題:Python queue.Queue方法的具體用法?Python queue.Queue怎麽用?Python queue.Queue使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在queue的用法示例。


在下文中一共展示了queue.Queue方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: main

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def main():
  print("Starting our Web Crawler")
  baseUrl = input("Website > ")
  numberOfThreads = input("No Threads > ")

  linksToCrawl = queue.Queue()
  urlLock = threading.Lock()
  linksToCrawl.put(baseUrl)
  haveVisited = []
  crawlers = []
  errorLinks = []

  for i in range(int(numberOfThreads)):
    crawler = Crawler(baseUrl, linksToCrawl, haveVisited, errorLinks, urlLock)
    crawler.start()
    crawlers.append(crawler)

  for crawler in crawlers:
    crawler.join()

  print("Total Number of Pages Visited {}".format(len(haveVisited)))
  print("Total Number of Pages with Errors {}".format(len(errorLinks))) 
開發者ID:PacktPublishing,項目名稱:Learning-Concurrency-in-Python,代碼行數:24,代碼來源:webCrawler.py

示例2: dd_iso_image

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def dd_iso_image(self, input_, output, gui_update, status_update):
        ''' Implementation for OS that use dd to write the iso image. 
        '''
        in_file_size = os.path.getsize(input_)
        cmd = [self.dd_exe, 'if=' + input_,
               'of=' + self.physical_disk(output), 'bs=1M']
        self.dd_iso_image_add_args(cmd, input_, output)
        kw_args = {
            'stdout' : subprocess.PIPE,
            'stderr' : subprocess.PIPE,
            'shell'  : False,
            }
        self.add_dd_iso_image_popen_args(kw_args)
        self.dd_iso_image_prepare(input, output, status_update)
        log('Executing => ' + str(cmd))
        dd_process = subprocess.Popen(cmd, **kw_args)
        output_q = queue.Queue()
        while dd_process.poll() is None:
            self.dd_iso_image_readoutput(dd_process, gui_update, in_file_size,
                                         output_q)
        output_lines = [output_q.get() for i in range(output_q.qsize())]
        for l in output_lines:
            log('dd: ' + l)
        return self.dd_iso_image_interpret_result(
            dd_process.returncode, output_lines) 
開發者ID:mbusb,項目名稱:multibootusb,代碼行數:27,代碼來源:osdriver.py

示例3: main

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def main():
    nloops = randint(2, 20)
    q = Queue(32)

    threads = []
    for i in nfuncs:
        t = MyThread(funcs[i], (q, nloops), funcs[i].__name__)
        threads.append(t)

    for i in nfuncs:
        threads[i].start()

    for i in nfuncs:
        threads[i].join()

    print("all DONE") 
開發者ID:wdxtub,項目名稱:deep-learning-note,代碼行數:18,代碼來源:8_prodcons.py

示例4: __init__

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def __init__(self, batch_size, input_length, nthreads=6, web_viz=False):
        super(RLDataIter, self).__init__()
        self.batch_size = batch_size
        self.input_length = input_length
        self.env = [self.make_env() for _ in range(batch_size)]
        self.act_dim = self.env[0].action_space.n

        self.state_ = None

        self.reset()

        self.provide_data = [mx.io.DataDesc('data', self.state_.shape, np.uint8)]

        self.web_viz = web_viz
        if web_viz:
            self.queue = queue.Queue()
            self.thread = Thread(target=make_web, args=(self.queue,))
            self.thread.daemon = True
            self.thread.start()

        self.nthreads = nthreads
        if nthreads > 1:
            self.pool = multiprocessing.pool.ThreadPool(6) 
開發者ID:awslabs,項目名稱:dynamic-training-with-apache-mxnet-on-aws,代碼行數:25,代碼來源:rl_data.py

示例5: itn_handler

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def itn_handler(host, port):  # type: (str, int) -> Iterator[Queue]
    """
    Usage::

        with itn_handler(ITN_HOST, ITN_PORT) as itn_queue:
            # ...complete PayFast payment...
            itn_data = itn_queue.get(timeout=2)
    """
    server_address = (host, port)
    http_server = HTTPServer(server_address, PayFastITNHandler)
    http_server.itn_queue = Queue()  # type: ignore

    executor = ThreadPoolExecutor(max_workers=1)
    executor.submit(http_server.serve_forever)
    try:
        yield http_server.itn_queue  # type: ignore
    finally:
        http_server.shutdown() 
開發者ID:PiDelport,項目名稱:django-payfast,代碼行數:20,代碼來源:itn_helpers.py

示例6: extractInfo

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def extractInfo(self):
        try:
            while not self.exit:
                try:
                    frame = self.frame_queue.get(block=True, timeout=1)
                except queue.Empty:
                    print("Queue empty")
                    continue
                try:
                    # Publish new image
                    msg = self.bridge.cv2_to_imgmsg(frame, 'rgb8')
                    if not self.exit:
                        self.image_publisher.publish(msg)
                except CvBridgeError as e:
                    print("Error Converting cv image: {}".format(e.message))
                self.frame_num += 1
        except Exception as e:
            print("Exception after loop: {}".format(e))
            raise 
開發者ID:sergionr2,項目名稱:RacingRobot,代碼行數:21,代碼來源:camera_node.py

示例7: _check_and_execute

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def _check_and_execute(self):
        wakeup_queue = self._wakeup_queue
        while 1:
            (next_expired_time, expired_timers) = self._get_expired_timers()
            for timer in expired_timers:
                try:
                    # Note, please make timer callback effective/short
                    timer()
                except Exception:
                    logging.error(traceback.format_exc())

            self._reset_timers(expired_timers)

            sleep_time = _calc_sleep_time(next_expired_time)
            try:
                wakeup = wakeup_queue.get(timeout=sleep_time)
                if wakeup is TEARDOWN_SENTINEL:
                    break
            except Queue.Empty:
                pass
        logging.info('TimerQueue stopped.') 
開發者ID:remg427,項目名稱:misp42splunk,代碼行數:23,代碼來源:timer_queue.py

示例8: __init__

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def __init__(self, job_scheduler, event_writer):
        """
        @configs: a list like object containing a list of dict
        like object. Each element shall implement dict.get/[] like interfaces
        to get the value for a key.
        @job_scheduler: schedulering the jobs. shall implement get_ready_jobs
        @event_writer: write_events
        """

        self._settings = self._read_default_settings()
        self._settings["daemonize_thread"] = False
        self._event_writer = event_writer
        self._wakeup_queue = queue.Queue()
        self._scheduler = job_scheduler
        self._timer_queue = tq.TimerQueue()
        self._executor = ce.ConcurrentExecutor(self._settings)
        self._started = False 
開發者ID:remg427,項目名稱:misp42splunk,代碼行數:19,代碼來源:ta_data_loader.py

示例9: __init__

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def __init__(self, loader, split, ix_gen, max_items):
        """
        :param loader: Object responsible for loading samples.
        :param split: train, val or test.
        :param ix_gen: An infinite generator yielding tuples (ix, n).
        :param max_items: The maximum number of samples to have in the
                          queue.
        """
        super().__init__()
        self.ix_gen = ix_gen
        self.outq = queue.Queue(max_items)
        self.split = split
        self.loader = loader
        self.daemon = True 
開發者ID:mme,項目名稱:vergeml,代碼行數:16,代碼來源:loader.py

示例10: __get__

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def __get__(self, inst, owner):
        if inst is None:
            return self
        key = self._func.__get__(inst, type(inst))
        if key not in self._queues:
            self._queues[key] = queue.Queue()
            self._threads[key] = threading.Thread(target=self._thread_loop, args=[inst, key])
            self._threads[key].daemon = True
            self._threads[key].start()
        return lambda *a, **k: self._queues[key].put((a, k)) 
開發者ID:pkkid,項目名稱:pkmeter,代碼行數:12,代碼來源:decorators.py

示例11: iter_responses

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def iter_responses(urls, data=None, timeout=30):
    responses = queue.Queue()
    threads = []
    _req = lambda url, data, timeout: responses.put(http_request(url, data, timeout))
    for url in urls:
        threads.append(threading.Thread(target=_req, args=(url, data, timeout)))
        threads[-1].daemon = True
        threads[-1].start()
    for thread in threads:
        thread.join()
    responses.put(None)
    for response in iter(responses.get, None):
        yield response 
開發者ID:pkkid,項目名稱:pkmeter,代碼行數:15,代碼來源:utils.py

示例12: mySubscriber

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def mySubscriber(queue):
  while True:
    item = queue.get()
    if item is None:
      break
    print("{} removed {} from the queue".format(threading.current_thread(), item))
    print("Queue Size is now: {}".format(queue.qsize()))
    queue.task_done() 
開發者ID:PacktPublishing,項目名稱:Learning-Concurrency-in-Python,代碼行數:10,代碼來源:queueOperations.py

示例13: preload_streamed_response_content_async

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def preload_streamed_response_content_async(requests_response_obj, buffer_queue):
    """
    stream模式下, 預讀遠程響應的content
    :param requests_response_obj:
    :type buffer_queue: queue.Queue
    """
    for particle_content in requests_response_obj.iter_content(stream_transfer_buffer_size):
        try:
            buffer_queue.put(particle_content, timeout=10)
        except queue.Full:  # coverage: exclude
            traceback.print_exc()
            exit()
        if verbose_level >= 3: dbgprint('BufferSize', buffer_queue.qsize())
    buffer_queue.put(None, timeout=10)
    exit() 
開發者ID:aploium,項目名稱:zmirror,代碼行數:17,代碼來源:zmirror.py

示例14: __init__

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def __init__(
            self, queue, target
    ):
        """
        :type queue: queue.Queue
        """
        super(StoppableThread, self).__init__()
        self.task_func = target
        self.queue = queue
        self.daemon = True
        self._stopped = False 
開發者ID:winkidney,項目名稱:PickTrue,代碼行數:13,代碼來源:engine.py

示例15: __init__

# 需要導入模塊: import queue [as 別名]
# 或者: from queue import Queue [as 別名]
def __init__(self):
        self.recv_queue = Queue()
        self.send_queue = Queue() 
開發者ID:winkidney,項目名稱:PickTrue,代碼行數:5,代碼來源:channel.py


注:本文中的queue.Queue方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。