Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
S
search_tips
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
rank
search_tips
Commits
65505254
Commit
65505254
authored
Dec 26, 2019
by
李小芳
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'highlight' into 'master'
Highlight See merge request
!39
parents
2f6c7c4c
7a6e1e35
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
51 additions
and
1 deletion
+51
-1
auto_tips.py
search/utils/auto_tips.py
+51
-1
No files found.
search/utils/auto_tips.py
View file @
65505254
...
@@ -114,6 +114,8 @@ def get_suggest_tips(query, lat, lng, offset=0, size=50):
...
@@ -114,6 +114,8 @@ def get_suggest_tips(query, lat, lng, offset=0, size=50):
get_tag_wiki_data
=
list
()
get_tag_wiki_data
=
list
()
have_read_tips_set
=
set
()
have_read_tips_set
=
set
()
ret_list
=
list
()
ret_list
=
list
()
doctor_hospital_equal_query
=
list
()
tag_equal_query
=
list
()
result_dict
=
ESPerform
.
get_search_results
(
ESPerform
.
get_cli
(),
sub_index_name
=
"suggest"
,
query_body
=
q
,
result_dict
=
ESPerform
.
get_search_results
(
ESPerform
.
get_cli
(),
sub_index_name
=
"suggest"
,
query_body
=
q
,
offset
=
offset
,
size
=
size
,
is_suggest_request
=
True
)
offset
=
offset
,
size
=
size
,
is_suggest_request
=
True
)
...
@@ -148,17 +150,29 @@ def get_suggest_tips(query, lat, lng, offset=0, size=50):
...
@@ -148,17 +150,29 @@ def get_suggest_tips(query, lat, lng, offset=0, size=50):
else
:
else
:
hit_item
[
"_source"
][
"describe"
]
=
""
hit_item
[
"_source"
][
"describe"
]
=
""
if
hit_item
[
"_source"
][
"ori_name"
]
==
query
:
doctor_hospital_equal_query
.
append
(
hit_item
[
"_source"
])
else
:
get_doctor_hospital_data
.
append
(
hit_item
[
"_source"
])
get_doctor_hospital_data
.
append
(
hit_item
[
"_source"
])
else
:
else
:
if
hit_item
[
"_source"
][
"type_flag"
]
==
"doctor"
:
if
hit_item
[
"_source"
][
"type_flag"
]
==
"doctor"
:
hit_item
[
"_source"
][
"describe"
]
=
""
hit_item
[
"_source"
][
"describe"
]
=
""
if
hit_item
[
"_source"
][
"ori_name"
]
==
query
:
doctor_hospital_equal_query
.
append
(
hit_item
[
"_source"
])
else
:
get_doctor_hospital_data
.
append
(
hit_item
[
"_source"
])
get_doctor_hospital_data
.
append
(
hit_item
[
"_source"
])
else
:
else
:
hit_item
[
"_source"
][
"describe"
]
=
"约"
+
str
(
hit_item
[
"_source"
][
"results_num"
])
+
"个结果"
if
\
hit_item
[
"_source"
][
"describe"
]
=
"约"
+
str
(
hit_item
[
"_source"
][
"results_num"
])
+
"个结果"
if
\
hit_item
[
"_source"
][
"results_num"
]
else
""
hit_item
[
"_source"
][
"results_num"
]
else
""
if
hit_item
[
"_source"
][
"ori_name"
]
==
query
:
tag_equal_query
.
append
(
hit_item
[
"_source"
])
else
:
get_tag_wiki_data
.
append
(
hit_item
[
"_source"
])
get_tag_wiki_data
.
append
(
hit_item
[
"_source"
])
ret_list
.
extend
(
tag_equal_query
)
ret_list
.
extend
(
doctor_hospital_equal_query
)
ret_list
.
extend
(
get_tag_wiki_data
)
ret_list
.
extend
(
get_tag_wiki_data
)
ret_list
.
extend
(
get_doctor_hospital_data
)
ret_list
.
extend
(
get_doctor_hospital_data
)
...
@@ -172,7 +186,7 @@ def get_suggest_tips(query, lat, lng, offset=0, size=50):
...
@@ -172,7 +186,7 @@ def get_suggest_tips(query, lat, lng, offset=0, size=50):
QUERY_KEY
=
"query:search_tip"
QUERY_KEY
=
"query:search_tip"
query_base64
=
base64
.
b64encode
(
query
.
encode
(
'utf8'
))
.
decode
(
'utf8'
)
query_base64
=
base64
.
b64encode
(
query
.
encode
(
'utf8'
))
.
decode
(
'utf8'
)
if
redis_client
.
hget
(
QUERY_KEY
,
query_base64
)
is
not
None
:
if
redis_client
.
hget
(
QUERY_KEY
,
query_base64
)
is
not
None
:
value_data
=
json
.
loads
(
str
(
redis_client
.
hget
(
QUERY_KEY
,
query_base64
),
encoding
=
'utf-8'
))
value_data
=
json
.
loads
(
str
(
redis_client
.
hget
(
QUERY_KEY
,
query_base64
),
encoding
=
'utf-8'
))
if
len
(
value_data
)
>
0
:
if
len
(
value_data
)
>
0
:
for
i
in
value_data
:
for
i
in
value_data
:
...
@@ -192,13 +206,49 @@ def get_suggest_tips(query, lat, lng, offset=0, size=50):
...
@@ -192,13 +206,49 @@ def get_suggest_tips(query, lat, lng, offset=0, size=50):
"type_flag"
:
get_tips_word_type
(
ori_name
),
"highlight_name"
:
highlight_name
,
"type_flag"
:
get_tips_word_type
(
ori_name
),
"highlight_name"
:
highlight_name
,
"describe"
:
describe
})
"describe"
:
describe
})
else
:
else
:
wordresemble_ret_list
.
append
(
wordresemble_ret_list
.
append
(
{
"results_num"
:
result_num
,
"ori_name"
:
ori_name
,
"id"
:
None
,
"is_online"
:
True
,
{
"results_num"
:
result_num
,
"ori_name"
:
ori_name
,
"id"
:
None
,
"is_online"
:
True
,
"offline_score"
:
0
,
"offline_score"
:
0
,
"type_flag"
:
get_tips_word_type
(
ori_name
),
"highlight_name"
:
highlight_name
,
"type_flag"
:
get_tips_word_type
(
ori_name
),
"highlight_name"
:
highlight_name
,
"describe"
:
describe
})
"describe"
:
describe
})
ret_list
.
extend
(
query_ret_list
)
ret_list
.
extend
(
query_ret_list
)
ret_list
.
extend
(
wordresemble_ret_list
)
ret_list
.
extend
(
wordresemble_ret_list
)
###高亮调整
query_ret_list
.
extend
(
wordresemble_ret_list
)
for
ret
in
query_ret_list
:
query2
=
ret
[
"ori_name"
]
for
item
in
range
(
0
,
len
(
query
)):
is_find
=
query2
.
find
(
query
[
item
])
high_query
=
None
if
is_find
>=
0
:
highlight_marks
=
u'<ems>
%
s</ems>'
%
query
[
item
]
high_query
=
query2
.
replace
(
query
[
item
],
highlight_marks
)
query2
=
high_query
if
high_query
==
None
:
ret
[
"highlight_name"
]
=
query2
else
:
ret
[
"highlight_name"
]
=
high_query
###繁体字删掉,把搜索结果加到简体字上边
fanti_query
=
[{
'痩脸针'
:
"瘦脸针"
}]
for
item
in
ret_list
:
result_num
=
[[
item
[
'results_num'
],
list
(
ret
.
values
())[
0
],
list
(
ret
.
keys
())[
0
]]
for
ret
in
fanti_query
if
list
(
ret
.
keys
())[
0
]
==
item
[
'ori_name'
]]
if
len
(
result_num
)
>
0
:
ret_list
.
remove
(
item
)
for
item
in
ret_list
:
if
item
[
'ori_name'
]
==
result_num
[
0
][
1
]:
item
[
'results_num'
]
+=
result_num
[
0
][
0
]
####
if
len
(
ret_list
)
>=
50
:
if
len
(
ret_list
)
>=
50
:
return
ret_list
[
0
:
50
]
return
ret_list
[
0
:
50
]
else
:
else
:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment