mirror of
https://github.com/searxng/searxng
synced 2024-11-09 01:10:26 +00:00
53 lines
1.1 KiB
Python
53 lines
1.1 KiB
Python
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']}
|