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


Python celery.group方法代碼示例

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


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

示例1: extract_functionnames_regex

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def extract_functionnames_regex(file_path, exported_only=False):
    rproc = "(^|;|};?|public:|private:)"  # group 1: begining of source line
    rproc += "\s*"  # optional whitespace(s)
    rproc += "([\w_][\w\s\d_,<>\[\].&:\*]*)"  # group 2: return type (includes associated class)
    rproc += "\s+"  # mandatory whitespace(s)
    rproc += "(\*|[\*|\w_][\w\d_<>\*\[\]&]*::)?"  # group 3: # group 3: optional class/pointer type
    rproc += "([\w_][\w\d_]*)"  # group 4: function name
    rproc += "\s*"  # optional whitespace(s)
    rproc += "\("  # '(' start of parameters
    rproc += "([\w\s,<>\[\].=&':/*]*)"  # group 4: parameters
    rproc += "\)"  # ')' end of parameters
    rproc += "\s*"  # optional whitespace(s)
    rproc += "([\w\s\d_]*)"  # group 5: optional attribute
    rproc += "\s*"  # optional whitespace(s)
    rproc += "{"  # '{' function start

    p = re.compile(rproc)
    exclude = ['if', 'while', 'do', 'for', 'switch']
    for x in p.finditer(loadtxt(file_path)):
        if x.group(4) in exclude or (exported_only and 'static' in x.group(2)):
            continue
        yield x.group(4) 
開發者ID:osssanitizer,項目名稱:osspolice,代碼行數:24,代碼來源:signature.py

示例2: getDeep

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def getDeep():
	result = {}
	for i in range(deep):
		if result:
			# те айди, которых нет в ключах + не берем id:None
			lst = list(set([item for sublist in result.values() if sublist for item in sublist]) - set(result.keys()))
			d_friends = group(deep_friends.s(i) for i in parts(list(lst), 75))().get()
			result = {k: v for d in d_friends for k, v in d.items()}
			result.update(result)
		else:
			all_friends = friends(my_id)
			d_friends = group(deep_friends.s(i) for i in parts(list(all_friends[0].keys()), 75) )().get()
			result = {k: v for d in d_friends for k, v in d.items()}
			result.update(result)

	return cleaner(result) 
開發者ID:stleon,項目名稱:vk_friends,代碼行數:18,代碼來源:call.py

示例3: compute_threshold

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def compute_threshold(self, thresh):
        # split task into 1024 chunks (too many subtasks causes a backlog
        # error)
        chunksize = len(self.decomp_ids) / 1024
        print 'Queuing %s items (chunksize %s) for threshold %s...' % (
            len(self.decomp_ids), chunksize, thresh)

        job = group([
            evaluate_decompositions_task.subtask(kwargs={
                'decomposition_ids': ids,
                'delete_failed_open': False,
                'thresh': thresh,
            })
            for ids in chunk_list_generator(self.decomp_ids, chunksize)
        ])
        result = job.apply_async()

        print 'Waiting on %s subtasks with chunksize %s...' % (
            len(self.decomp_ids) / chunksize, chunksize)

        result.join() 
開發者ID:seanbell,項目名稱:opensurfaces,代碼行數:23,代碼來源:intrinsic_results_sweep_thresh.py

示例4: _get_inference_job_signature

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def _get_inference_job_signature(self, imageIDs, maxNumWorkers=-1):
        '''
            Assembles (but does not submit) an inference job based on the provided parameters.
        '''
        # setup
        if maxNumWorkers != 1:
            # only query the number of available workers if more than one is specified to save time
            num_available = self._get_num_available_workers()
            if maxNumWorkers == -1:
                maxNumWorkers = num_available   #TODO: more than one process per worker?
            else:
                maxNumWorkers = min(maxNumWorkers, num_available)

        # distribute across workers
        images_subset = array_split(imageIDs, max(1, len(imageIDs) // maxNumWorkers))
        jobs = []
        for subset in images_subset:
            job = celery_interface.call_inference.si(imageIDs=subset)
            jobs.append(job)

        jobGroup = group(jobs)
        return jobGroup 
開發者ID:microsoft,項目名稱:aerial_wildlife_detection,代碼行數:24,代碼來源:middleware.py

示例5: run

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def run(self, query, options=None):
        """
        https://celery.readthedocs.io/en/latest/userguide/canvas.html#groups
        """

        logger.info('Starting download with query=%s, options=%s', query, options)

        # http://docs.celeryproject.org/en/latest/userguide/calling.html

        if isinstance(query, str):
            query = {'number': query}

        if isinstance(query, dict):
            self.task = self.task_function.delay(query, options)

        elif isinstance(query, list):
            tasks = [self.task_function.s(query, options) for query in query]
            task_group = celery.group(tasks)
            self.task = task_group.delay()

        else:
            raise TypeError('Unknown type for query {}. type={}'.format(query, type(query)))

        return self.task 
開發者ID:ip-tools,項目名稱:uspto-opendata-python,代碼行數:26,代碼來源:tasks.py

示例6: mandelbrot_main

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def mandelbrot_main(w, h, max_iterations=1000, output='mandelbrot_celery.png'):
    """ Main function for mandelbrot program with celery """
    
    job = group([mandelbrot_calc_row.s(y, w, h, max_iterations) for y in range(h)])
    result = job.apply_async()

    image = Image.new('RGB', (w, h))
    
    for image_rows in result.join():
        for k,v in image_rows.items():
            k = int(k)
            v = tuple(map(int, v))
            x,y = k % args.width, k // args.width
            image.putpixel((x,y), v)
            
    image.save(output, 'PNG')
    print('Saved to',output) 
開發者ID:PacktPublishing,項目名稱:Software-Architecture-with-Python,代碼行數:19,代碼來源:celery_mandelbrot.py

示例7: authorize_exam_runs

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def authorize_exam_runs():
    """
    Check for outstanding exam runs
    """
    for exam_run in ExamRun.objects.filter(
            authorized=False,
            date_first_schedulable__lte=now_in_utc(),
    ):
        enrollment_ids_qset = ProgramEnrollment.objects.filter(
            program=exam_run.course.program).values_list('id', flat=True)
        # create a group of subtasks
        job = group(
            authorize_enrollment_for_exam_run.s(enrollment_ids, exam_run.id)
            for enrollment_ids in chunks(enrollment_ids_qset)
        )
        job.apply_async()
        exam_run.authorized = True
        exam_run.save() 
開發者ID:mitodl,項目名稱:micromasters,代碼行數:20,代碼來源:tasks.py

示例8: build_report_task

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def build_report_task(results, ref_date):
    all_repos = []
    for repos in results:
        all_repos += [Repository(repo) for repo in repos]

    # 3. group by language
    grouped_repos = {}
    for repo in all_repos:
        if repo.language in grouped_repos:
            grouped_repos[repo.language].append(repo.name)
        else:
            grouped_repos[repo.language] = [repo.name]

    # 4. create csv
    lines = []
    for lang in sorted(grouped_repos.keys()):
        lines.append([lang] + grouped_repos[lang])

    filename = '{media}/github-hot-repos-{date}.csv'.format(media=settings.MEDIA_ROOT, date=ref_date)
    return make_csv(filename, lines) 
開發者ID:Rustem,項目名稱:toptal-blog-celery-toy-ex,代碼行數:22,代碼來源:tasks.py

示例9: extract_strings_regex

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def extract_strings_regex(file_path):
    """
    Function to extract strings from a C source file.
    """
    # get all strings in this repo
    p = re.compile(
        r'(?P<prefix>(?:\bu8|\b[LuU])?)(?:"(?P<dbl>[^"\\]*(?:\\.[^"\\]*)*)"|\'(?P<sngl>[^\'\\]*(?:\\.[^\'\\]*)*)\')|R"([^"(]*)\((?P<raw>.*?)\)\4"')

    with open(file_path) as ins:
        for line in ins:
            line = line.rstrip('\n')

            # filter out "include *.c|cpp|cc|h"
            if re.search(r'\s*#\s*include\s*(?:<([^>]*)>|"([^"]*)")', line):
                continue

            # filter comments
            if re.search('//.*?\n|/\*.*?\*/|^\s*\*\s.*$', line):
                continue

            # iterate over them
            for x in p.finditer(line):
                if x.group("dbl"):
                    line = x.group("dbl")
                elif x.group("sngl"):
                    continue
                else:
                    line = x.group("raw")
                yield line 
開發者ID:osssanitizer,項目名稱:osspolice,代碼行數:31,代碼來源:signature.py

示例10: replace_scope_in_params

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def replace_scope_in_params(s):
    if s.group() == "std::":
        return s.group()
    else:
        return ''


###########################################################
# Lookup library
########################################################### 
開發者ID:osssanitizer,項目名稱:osspolice,代碼行數:12,代碼來源:searching.py

示例11: assign_task

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def assign_task(end):
    from celery import group
    from remote import gen_prime  # This has to be imported
    job = group(gen_prime.s(2 ** i) for i in range(end))
    result = job.apply_async()
    result.get() 
開發者ID:osssanitizer,項目名稱:osspolice,代碼行數:8,代碼來源:remote.py

示例12: getMutual

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def getMutual():
	all_friends = friends(my_id)
	c_friends = group(mutual_friends.s(i) for i in parts(list(all_friends[0].keys()), 75))().get()
	result = {k: v for d in c_friends for k, v in d.items()}
	return cleaner(result) 
開發者ID:stleon,項目名稱:vk_friends,代碼行數:7,代碼來源:call.py

示例13: _gen_jobs

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def _gen_jobs(self, topic):
        jobs = []
        for job in self.subscribed:
            if job[1].match(topic):
                jobs.append(job[2].s())
        self.jobs[topic] = celery.group(jobs) 
開發者ID:Mulugruntz,項目名稱:celery-pubsub,代碼行數:8,代碼來源:pubsub.py

示例14: run

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def run(self, *args, **kwargs):
        with session_manager() as db_session:
            domain_list = crud_domain.get_domain_list(db_session)
            load_domain_extra_data_task = group([
                LoadDomainExtraDataTask().s(domain.id)
                for domain in domain_list
            ])
            load_result = load_domain_extra_data_task.delay()
            with allow_join_result():
                load_result.join()

            return self.set_result() 
開發者ID:QAX-A-Team,項目名稱:LuWu,代碼行數:14,代碼來源:domain.py

示例15: handle

# 需要導入模塊: import celery [as 別名]
# 或者: from celery import group [as 別名]
def handle(self, *args, **options):
        thresh = 0.10

        qset = IntrinsicImagesDecomposition.objects.all() \
            .exclude(error_comparison_thresh=thresh) \
            .values_list('id', flat=True)

        delete_failed_open = False
        if len(args) >= 1 and args[0] == "delete-failed-open":
            delete_failed_open = True

        print 'delete_failed_open: %s' % delete_failed_open

        qset = list(qset)
        random.shuffle(qset)

        chunksize = max(len(qset) / 1024, 1)
        print 'Queuing tasks in chunks of %s items...' % chunksize
        job = group([
            evaluate_decompositions_task.subtask(kwargs={
                'decomposition_ids': ids,
                'delete_failed_open': delete_failed_open,
                'thresh': thresh,
            })
            for ids in chunk_list_generator(qset, chunksize)
        ])
        job.apply_async()

        print 'Done' 
開發者ID:seanbell,項目名稱:opensurfaces,代碼行數:31,代碼來源:intrinsic_evaluate_all.py


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