api_search.py 1.1 KB

1234567891011121314151617181920212223242526272829303132333435
  1. from .tool.func import *
  2. def api_search_2(conn, name):
  3. curs = conn.cursor()
  4. num = int(number_check(flask.request.args.get('num', '10')))
  5. if not num > 0:
  6. num = 1
  7. if num > 1000:
  8. num = 1
  9. page = int(number_check(flask.request.args.get('page', '1')))
  10. if page * num > 0:
  11. page = page * num - num
  12. else:
  13. page = 0
  14. curs.execute(db_change('select data from other where name = "count_all_title"'))
  15. if int(curs.fetchall()[0][0]) < 10000:
  16. curs.execute(db_change("" + \
  17. "select distinct title, case when title like ? then 'title' else 'data' " + \
  18. "end from data where title like ? or data like ? order by case " + \
  19. "when title like ? then 1 else 2 end limit ?, ?"),
  20. ['%' + name + '%', '%' + name + '%', '%' + name + '%', '%' + name + '%', page, num]
  21. )
  22. else:
  23. curs.execute(db_change("select title from data where title like ? order by title limit ?, 50"),
  24. ['%' + name + '%', sql_num]
  25. )
  26. all_list = curs.fetchall()
  27. if all_list:
  28. return flask.jsonify(all_list)
  29. else:
  30. return flask.jsonify({})