main_search_deep.py 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  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"), ['%' + name + '%', sql_num])
  47. else:
  48. curs.execute(db_change("select title from data where data like ? collate nocase order by title limit ?, 50"), ['%' + name + '%', sql_num])
  49. all_list = curs.fetchall()
  50. for data in all_list:
  51. div += '<li><a href="/w/' + url_pas(data[0]) + '">' + data[0] + '</a></li>'
  52. div += '</ul>'
  53. if search_type == 'title':
  54. div += get_next_page_bottom('/search/{}/' + url_pas(name), num, all_list)
  55. else:
  56. div += get_next_page_bottom('/search_data/{}/' + url_pas(name), num, all_list)
  57. return easy_minify(flask.render_template(skin_check(),
  58. imp = [name, wiki_set(), wiki_custom(), wiki_css(['(' + load_lang('search') + ')', 0])],
  59. data = div,
  60. menu = 0
  61. ))