2
0

main_search_deep.py 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. from .tool.func import *
  2. def main_search_deep(name = 'Test', search_type = 'title', num = 1):
  3. with get_db_connect() as conn:
  4. curs = conn.cursor()
  5. if name == '':
  6. return redirect()
  7. sql_num = (num * 50 - 50) if num * 50 > 0 else 0
  8. if flask.request.method == 'POST':
  9. if search_type == 'title':
  10. return redirect('/search/1/' + url_pas(flask.request.form.get('search', 'test')))
  11. else:
  12. return redirect('/search_data/1/' + url_pas(flask.request.form.get('search', 'test')))
  13. else:
  14. div = '''
  15. <form method="post">
  16. <input class="opennamu_width_200" name="search" value="''' + html.escape(name) + '''">
  17. <button type="submit">''' + load_lang('search') + '''</button>
  18. </form>
  19. <hr class="main_hr">
  20. '''
  21. if search_type == 'title':
  22. div += '<a href="/search_data/1/' + url_pas(name) + '">(' + load_lang('search_document_data') + ')</a>'
  23. else:
  24. div += '<a href="/search/1/' + url_pas(name) + '">(' + load_lang('search_document_name') + ')</a>'
  25. name_new = ''
  26. if re.search(r'^분류:', name):
  27. name_new = re.sub(r"^분류:", 'category:', name)
  28. elif re.search(r"^사용자:", name):
  29. name_new = re.sub(r"^사용자:", 'user:', name)
  30. elif re.search(r"^파일:", name):
  31. name_new = re.sub(r"^파일:", 'file:', name)
  32. if name_new != '':
  33. div += ' <a href="/search/1/' + url_pas(name_new) + '">(' + name_new + ')</a>'
  34. curs.execute(db_change("select title from data where title = ? collate nocase"), [name])
  35. link_id = '' if curs.fetchall() else 'class="opennamu_not_exist_link"'
  36. div += '''
  37. <ul class="opennamu_ul">
  38. <li>
  39. <a ''' + link_id + ' href="/w/' + url_pas(name) + '">' + html.escape(name) + '''</a>
  40. </li>
  41. </ul>
  42. <hr class="main_hr">
  43. <ul class="opennamu_ul">
  44. '''
  45. if search_type == 'title':
  46. curs.execute(db_change("select title from data where title like ? collate nocase order by title limit ?, 50"),
  47. ['%' + name + '%', sql_num]
  48. )
  49. else:
  50. curs.execute(db_change("select title from data where data like ? collate nocase order by title limit ?, 50"),
  51. ['%' + name + '%', sql_num]
  52. )
  53. all_list = curs.fetchall()
  54. for data in all_list:
  55. div += '<li><a href="/w/' + url_pas(data[0]) + '">' + data[0] + '</a></li>'
  56. div += '</ul>'
  57. if search_type == 'title':
  58. div += get_next_page_bottom('/search/{}/' + url_pas(name), num, all_list)
  59. else:
  60. div += get_next_page_bottom('/search_data/{}/' + url_pas(name), num, all_list)
  61. return easy_minify(flask.render_template(skin_check(),
  62. imp = [name, wiki_set(), wiki_custom(), wiki_css(['(' + load_lang('search') + ')', 0])],
  63. data = div,
  64. menu = 0
  65. ))