mirror of
				https://github.com/searxng/searxng.git
				synced 2025-11-04 03:27:06 -05:00 
			
		
		
		
	In the past, some files were tested with the standard profile, others with a profile in which most of the messages were switched off ... some files were not checked at all. - ``PYLINT_SEARXNG_DISABLE_OPTION`` has been abolished - the distinction ``# lint: pylint`` is no longer necessary - the pylint tasks have been reduced from three to two 1. ./searx/engines -> lint engines with additional builtins 2. ./searx ./searxng_extra ./tests -> lint all other python files Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
		
			
				
	
	
		
			52 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# SPDX-License-Identifier: AGPL-3.0-or-later
 | 
						|
from functools import reduce
 | 
						|
from operator import mul
 | 
						|
 | 
						|
from flask_babel import gettext
 | 
						|
 | 
						|
 | 
						|
keywords = ('min', 'max', 'avg', 'sum', 'prod')
 | 
						|
 | 
						|
 | 
						|
# required answerer function
 | 
						|
# can return a list of results (any result type) for a given query
 | 
						|
def answer(query):
 | 
						|
    parts = query.query.split()
 | 
						|
 | 
						|
    if len(parts) < 2:
 | 
						|
        return []
 | 
						|
 | 
						|
    try:
 | 
						|
        args = list(map(float, parts[1:]))
 | 
						|
    except:
 | 
						|
        return []
 | 
						|
 | 
						|
    func = parts[0]
 | 
						|
    answer = None
 | 
						|
 | 
						|
    if func == 'min':
 | 
						|
        answer = min(args)
 | 
						|
    elif func == 'max':
 | 
						|
        answer = max(args)
 | 
						|
    elif func == 'avg':
 | 
						|
        answer = sum(args) / len(args)
 | 
						|
    elif func == 'sum':
 | 
						|
        answer = sum(args)
 | 
						|
    elif func == 'prod':
 | 
						|
        answer = reduce(mul, args, 1)
 | 
						|
 | 
						|
    if answer is None:
 | 
						|
        return []
 | 
						|
 | 
						|
    return [{'answer': str(answer)}]
 | 
						|
 | 
						|
 | 
						|
# required answerer function
 | 
						|
# returns information about the answerer
 | 
						|
def self_info():
 | 
						|
    return {
 | 
						|
        'name': gettext('Statistics functions'),
 | 
						|
        'description': gettext('Compute {functions} of the arguments').format(functions='/'.join(keywords)),
 | 
						|
        'examples': ['avg 123 548 2.04 24.2'],
 | 
						|
    }
 |