mark.py 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. from set_mark.namu import namu
  2. import re
  3. import html
  4. import sqlite3
  5. import urllib.parse
  6. import time
  7. import threading
  8. import multiprocessing
  9. def load_conn2(data):
  10. global conn
  11. global curs
  12. conn = data
  13. curs = conn.cursor()
  14. def send_parser(data):
  15. if not re.search('^<br>$', data):
  16. data = html.escape(data)
  17. javascript = re.compile('javascript:', re.I)
  18. data = javascript.sub('', data)
  19. while 1:
  20. re_data = re.search('&lt;a(?: (?:(?:(?!&gt;).)*))?&gt;(?P<in>(?:(?!&lt;).)*)&lt;\/a&gt;', data)
  21. if re_data:
  22. re_data = re_data.groups()[0]
  23. data = re.sub('&lt;a(?: (?:(?:(?!&gt;).)*))?&gt;(?P<in>(?:(?!&lt;).)*)&lt;\/a&gt;', '<a href="/w/' + urllib.parse.quote(re_data).replace('/','%2F') + '">' + re_data + '</a>', data, 1)
  24. else:
  25. break
  26. return data
  27. def plusing(data):
  28. for data_in in data:
  29. curs.execute("select title from back where title = ? and link = ? and type = ?", [data_in[1], data_in[0], data_in[2]])
  30. if not curs.fetchall():
  31. curs.execute("insert into back (title, link, type) values (?, ?, ?)", [data_in[1], data_in[0], data_in[2]])
  32. def namumark(title = '', data = '', num = 0):
  33. if not data == '':
  34. data = namu(conn, data, title, num)
  35. if num == 1:
  36. data_num = len(data[2])
  37. data_in_num = int(data_num / 8)
  38. data_in = []
  39. for i in range(8):
  40. if not i == 7:
  41. data_in += [data[2][data_in_num * i:data_in_num * (i + 1)]]
  42. else:
  43. data_in += [data[2][data_in_num * i:]]
  44. for data_in_for in data_in:
  45. thread_start = threading.Thread(target = plusing, args = [data_in_for])
  46. thread_start.start()
  47. thread_start.join()
  48. conn.commit()
  49. return data[0] + data[1]
  50. else:
  51. return '404'