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


Python concurrent.futures方法代碼示例

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


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

示例1: pool

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def pool(self):
        result = self.parse_html(self.host)
        try:
            with concurrent.futures.ThreadPoolExecutor(max_workers=30) as executor:
                futures = [executor.submit(self.parse_html, i) for i in result]
                for future in concurrent.futures.as_completed(futures, timeout=3):
                    future.result()
        except (EOFError, concurrent.futures._base.TimeoutError):
            pass
        except Exception as e:
            logging.exception(e)
        
        jslink = JsLeaks().pool(self.js)
        
        self.result.extend(jslink)
        self.result = list(set(self.result))
        
        for i in self.result:
            console('Crawl', self.host, i + '\n')
        
        Sqldb(self.dbname).get_crawl(self.domain, self.result) 
開發者ID:al0ne,項目名稱:Vxscan,代碼行數:23,代碼來源:crawl.py

示例2: test_future_traceback

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def test_future_traceback(self):
        @return_future
        @gen.engine
        def f(callback):
            yield gen.Task(self.io_loop.add_callback)
            try:
                1 / 0
            except ZeroDivisionError:
                self.expected_frame = traceback.extract_tb(
                    sys.exc_info()[2], limit=1)[0]
                raise
        try:
            yield f()
            self.fail("didn't get expected exception")
        except ZeroDivisionError:
            tb = traceback.extract_tb(sys.exc_info()[2])
            self.assertIn(self.expected_frame, tb)

# The following series of classes demonstrate and test various styles
# of use, with and without generators and futures. 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:22,代碼來源:concurrent_test.py

示例3: then

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def then(self, fn, deferred=False):
        result = Future(self._loop)
        result._register()

        def callback(_):
            try:
                if deferred:
                    temp = self._loop.run_later(fn, self.result())
                    temp.chain(result)
                elif not threading.current_thread() is self._loop:
                    temp = self._loop.run_async(fn, self.result())
                    temp.chain(result)
                else:
                    result.set_result(fn(self.result()))
            except Exception as e:
                self.logger.exception(
                    "Unhandled exception while chaining futures"
                )
                result.set_exception(e)
            except:
                result.cancel()

        self.add_done_callback(callback)
        return result 
開發者ID:Parrot-Developers,項目名稱:olympe,代碼行數:26,代碼來源:pomp_loop_thread.py

示例4: run_async

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def run_async(self, func, *args, **kwds):
        """
        Fills in a list with the function to be executed in the pomp thread
        and wakes up the pomp thread.
        """
        future = Future(self)
        future._register()

        if threading.current_thread() is not self:
            self.async_pomp_task.append((future, func, args, kwds))
            self._wake_up()
        else:
            try:
                ret = func(*args, **kwds)
            except Exception as e:
                self.logger.exception(
                    "Unhandled exception in async task function"
                )
                future.set_exception(e)
            else:
                if not isinstance(ret, concurrent.futures.Future):
                    future.set_result(ret)
                else:
                    ret.chain(future)
        return future 
開發者ID:Parrot-Developers,項目名稱:olympe,代碼行數:27,代碼來源:pomp_loop_thread.py

示例5: _run_task_list

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def _run_task_list(self, task_list):
        """
        execute all pending functions located in the task list
        this is done in the order the list has been filled in
        """
        while len(task_list):
            future, f, args, kwds = task_list.pop(0)
            try:
                ret = f(*args, **kwds)
            except Exception as e:
                self.logger.exception(
                    "Unhandled exception in async task function"
                )
                self._unregister_future(future, ignore_error=True)
                future.set_exception(e)
                continue
            if not isinstance(ret, concurrent.futures.Future):
                future.set_result(ret)
            else:
                ret.chain(future) 
開發者ID:Parrot-Developers,項目名稱:olympe,代碼行數:22,代碼來源:pomp_loop_thread.py

示例6: __init__

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def __init__(self, *args: Future, **kwargs: Future) -> None:
        if args and kwargs:
            raise ValueError("You must provide args or kwargs, not both")

        if kwargs:
            self._unfinished = dict((f, k) for (k, f) in kwargs.items())
            futures = list(kwargs.values())  # type: Sequence[Future]
        else:
            self._unfinished = dict((f, i) for (i, f) in enumerate(args))
            futures = args

        self._finished = collections.deque()  # type: Deque[Future]
        self.current_index = None  # type: Optional[Union[str, int]]
        self.current_future = None  # type: Optional[Future]
        self._running_future = None  # type: Optional[Future]

        for future in futures:
            future_add_done_callback(future, self._done_callback) 
開發者ID:opendevops-cn,項目名稱:opendevops,代碼行數:20,代碼來源:gen.py

示例7: download_file

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def download_file(self, bucket, key, filename, object_size,
                      extra_args, callback=None):
        with self._executor_cls(max_workers=2) as controller:
            # 1 thread for the future that manages the uploading of files
            # 1 thread for the future that manages IO writes.
            download_parts_handler = functools.partial(
                self._download_file_as_future,
                bucket, key, filename, object_size, callback)
            parts_future = controller.submit(download_parts_handler)

            io_writes_handler = functools.partial(
                self._perform_io_writes, filename)
            io_future = controller.submit(io_writes_handler)
            results = concurrent.futures.wait(
                [parts_future, io_future],
                return_when=concurrent.futures.FIRST_EXCEPTION)
            self._process_future_results(results) 
開發者ID:skarlekar,項目名稱:faces,代碼行數:19,代碼來源:__init__.py

示例8: download_all_images

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def download_all_images(self, photo_list: [OSCPhoto],
                            track_path: str,
                            override=False,
                            workers: int = 10):
        """This method will download all images to a path overriding or not the files at
        that path. By default this method uses 10 parallel workers."""
        with concurrent.futures.ThreadPoolExecutor(max_workers=workers) as executor:
            loop = asyncio.new_event_loop()
            futures = [
                loop.run_in_executor(executor,
                                     self.get_image, photo, track_path, override)
                for photo in photo_list
            ]
            if not futures:
                loop.close()
                return

            loop.run_until_complete(asyncio.gather(*futures))
            loop.close() 
開發者ID:openstreetcam,項目名稱:upload-scripts,代碼行數:21,代碼來源:osc_api_gateway.py

示例9: execute_runners

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def execute_runners(self, parallel=False, num_threads=1):
        '''
        Run each of the algorithms
        '''

        base_output_dir = self.output_settings.base_dir

        batches =  self.runners.keys()

        for batch in batches:
            if parallel==True:
                executor = concurrent.futures.ThreadPoolExecutor(max_workers=1)
                futures = [executor.submit(runner.run, base_output_dir)
                    for runner in self.runners[batch]]
                
                # https://stackoverflow.com/questions/35711160/detect-failed-tasks-in-concurrent-futures
                # Re-raise exception if produced
                for future in concurrent.futures.as_completed(futures):
                    future.result()
                executor.shutdown(wait=True)
            else:
                for runner in self.runners[batch]:
                    runner.run(output_dir=base_output_dir) 
開發者ID:Murali-group,項目名稱:Beeline,代碼行數:25,代碼來源:__init__.py

示例10: test_temp_table_concurrency

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def test_temp_table_concurrency(con, test_data_dir):
    # we don't install futures on windows in CI and we can't run this test
    # there anyway so we import here
    import concurrent.futures
    from concurrent.futures import as_completed

    def limit_10(i, hdfs_path):
        t = con.parquet_file(hdfs_path)
        return t.sort_by(t.r_regionkey).limit(1, offset=i).execute()

    nthreads = 4
    hdfs_path = pjoin(test_data_dir, 'parquet/tpch_region')

    with concurrent.futures.ThreadPoolExecutor(max_workers=nthreads) as e:
        futures = [e.submit(limit_10, i, hdfs_path) for i in range(nthreads)]
    assert all(map(len, (future.result() for future in as_completed(futures)))) 
開發者ID:ibis-project,項目名稱:ibis,代碼行數:18,代碼來源:test_ddl.py

示例11: test_async_await

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def test_async_await(self):
        class Object(object):
            def __init__(self):
                self.executor = futures.thread.ThreadPoolExecutor(1)

            @run_on_executor()
            def f(self):
                return 42

        o = Object()
        namespace = exec_test(globals(), locals(), """
        async def f():
            answer = await o.f()
            return answer
        """)
        result = yield namespace['f']()
        self.assertEqual(result, 42) 
開發者ID:tp4a,項目名稱:teleport,代碼行數:19,代碼來源:concurrent_test.py

示例12: wait_task

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def wait_task(self, return_when=concurrent.futures.FIRST_COMPLETED):
        """Waits for one or more running tasks to complete.

        Results of all completed tasks are copied into ``self.ready_task_results``.

        When no task is running, does nothing.

        """
        if len(self.running_tasks) > 0:
            self.config.log("Waiting for tasks to complete...")
            ready_tasks, self.running_tasks = concurrent.futures.wait(
                self.running_tasks, return_when=return_when
            )
            for task in ready_tasks:
                self.ready_task_results.append(task.result())

    # Overridden such that instances of search job can be pickled to workers 
開發者ID:uma-pi1,項目名稱:kge,代碼行數:19,代碼來源:search.py

示例13: run

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def run(self, task):
        try:
            with concurrent.futures.ThreadPoolExecutor(max_workers=THREADS) as executor:
                futures = [executor.submit(self.scan, i) for i in task]
                for future in concurrent.futures.as_completed(futures, timeout=3):
                    future.result()

        except (EOFError, concurrent.futures._base.TimeoutError):
            pass

    # 創建啟動任務 
開發者ID:al0ne,項目名稱:Vxscan,代碼行數:13,代碼來源:dir_scan.py

示例14: test_no_calling

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def test_no_calling(self):
        class Object(object):
            def __init__(self, io_loop):
                self.io_loop = io_loop
                self.executor = futures.thread.ThreadPoolExecutor(1)

            @run_on_executor
            def f(self):
                return 42

        o = Object(io_loop=self.io_loop)
        answer = yield o.f()
        self.assertEqual(answer, 42) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:15,代碼來源:concurrent_test.py

示例15: test_call_with_no_args

# 需要導入模塊: import concurrent [as 別名]
# 或者: from concurrent import futures [as 別名]
def test_call_with_no_args(self):
        class Object(object):
            def __init__(self, io_loop):
                self.io_loop = io_loop
                self.executor = futures.thread.ThreadPoolExecutor(1)

            @run_on_executor()
            def f(self):
                return 42

        o = Object(io_loop=self.io_loop)
        answer = yield o.f()
        self.assertEqual(answer, 42) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:15,代碼來源:concurrent_test.py


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