summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorasciimoo <asciimoo@gmail.com>2013-10-16 23:03:26 +0200
committerasciimoo <asciimoo@gmail.com>2013-10-16 23:03:26 +0200
commitfa9c9e090b6975987fac187f519dbf66f29eeed4 (patch)
tree7bcf7db727127b20ea21cd0b2b83f5f93e63813d
parenta1d15c3076154b2971d1030aa679ff0c088d625d (diff)
[enh] result ordering and deduplication
-rw-r--r--searx/engines/__init__.py22
1 files changed, 21 insertions, 1 deletions
diff --git a/searx/engines/__init__.py b/searx/engines/__init__.py
index 1dc1ea34f..d383f3608 100644
--- a/searx/engines/__init__.py
+++ b/searx/engines/__init__.py
@@ -4,6 +4,7 @@ from os import listdir
from imp import load_source
import grequests
from itertools import izip_longest, chain
+from operator import itemgetter
engine_dir = dirname(realpath(__file__))
@@ -56,4 +57,23 @@ def search(query, request, selected_engines):
)
requests.append(req)
grequests.map(requests)
- return list(filter(None, chain(*izip_longest(*results.values()))))
+ flat_res = list(filter(None, chain(*izip_longest(*results.values()))))
+ flat_len = len(flat_res)
+ results = []
+ # deduplication + scoring
+ for i,res in enumerate(flat_res):
+ score = flat_len - i
+ duplicated = False
+ for new_res in results:
+ if res['url'] == new_res['url']:
+ duplicated = new_res
+ break
+ if duplicated:
+ if len(res['content']) > len(duplicated):
+ duplicated['content'] = res['content']
+ duplicated['score'] += score
+ else:
+ res['score'] = score
+ results.append(res)
+
+ return sorted(results, key=itemgetter('score'), reverse=True)