namumark.py 50 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011
  1. from code import *
  2. json_data = open('set.json').read()
  3. data = json.loads(json_data)
  4. conn = pymysql.connect(host = data['host'], user = data['user'], password = data['pw'], charset = 'utf8mb4')
  5. curs = conn.cursor(pymysql.cursors.DictCursor)
  6. def DB_갱신():
  7. conn.commit()
  8. def URL_인코딩(데이터):
  9. return parse.quote(데이터).replace('/','%2F')
  10. def DB_가져오기():
  11. return curs.fetchall()
  12. DB_실행 = curs.execute
  13. DB_인코딩 = pymysql.escape_string
  14. DB_실행("use " + data['db'])
  15. def 세이브마크(데이터):
  16. 데이터 = re.sub("\[date\(now\)\]", 시간(), 데이터)
  17. if(not re.search("\.", 아이피_확인())):
  18. 이름 = '[[사용자:' + 아이피_확인() + '|' + 아이피_확인() + ']]'
  19. else:
  20. 이름 = 아이피_확인()
  21. 데이터 = re.sub("\[name\]", 이름, 데이터)
  22. return 데이터
  23. def HTML_파싱(데이터):
  24. while(True):
  25. 있나 = re.search("<((div|span|embed|iframe)(?:[^>]*))>", 데이터)
  26. if(있나):
  27. 분리 = 있나.groups()
  28. if(re.search("<(\/" + 분리[1] + ")>", 데이터)):
  29. XSS = re.search('src=(?:"|\')http(?:s)?:\/\/([^\/]*)\/(?:[^"\']*)(?:"|\')', 분리[0])
  30. if(XSS):
  31. 확인 = XSS.groups()
  32. if(확인[0] == "www.youtube.com" or 확인[0] == "serviceapi.nmv.naver.com" or 확인[0] == "tv.kakao.com" or 확인[0] == "tvple.com"):
  33. 임시_저장 = 분리[0]
  34. else:
  35. 임시_저장 = re.sub('src=(?:"|\')([^"\']*)(?:"|\')', '', 분리[0])
  36. else:
  37. 임시_저장 = 분리[0]
  38. 임시_저장 = re.sub('(?:"|\')', '#.#', 임시_저장)
  39. 데이터 = re.sub("<((?:\/)?" + 분리[1] + "(?:[^>]*))>", "[" + 임시_저장 + "]", 데이터, 1)
  40. 데이터 = re.sub("<\/" + 분리[1] + ">", "[/" + 분리[1] + "]", 데이터, 1)
  41. else:
  42. 데이터 = re.sub("<((?:\/)?" + 분리[1] + "(?:[^>]*))>", '&lt;' + 분리[0] + '&gt;', 데이터, 1)
  43. break
  44. else:
  45. break
  46. 데이터 = re.sub('<', '&lt;', 데이터)
  47. 데이터 = re.sub('>', '&gt;', 데이터)
  48. 데이터 = re.sub('"', '&quot;', 데이터)
  49. 데이터 = re.sub("\[(?P<in>(?:\/)?(?:div|span|embed|iframe)(?:[^\]]*))\]", "<\g<in>>", 데이터)
  50. 데이터 = re.sub('#.#', '"', 데이터)
  51. return 데이터
  52. def 중괄호_문법(데이터, 접기_숫자, 틀):
  53. while(True):
  54. 문법_컴파일 = re.compile("{{{((?:(?!{{{)(?!}}}).)*)}}}", re.DOTALL)
  55. 있나 = 문법_컴파일.search(데이터)
  56. if(있나):
  57. 분리 = 있나.groups()
  58. 크게_문법 = re.compile("^\+([1-5])\s(.*)$", re.DOTALL)
  59. 크게 = 크게_문법.search(분리[0])
  60. 작게_문법 = re.compile("^\-([1-5])\s(.*)$", re.DOTALL)
  61. 작게 = 작게_문법.search(분리[0])
  62. 색깔_문법_1 = re.compile("^(#[0-9a-f-A-F]{6})\s(.*)$", re.DOTALL)
  63. 색깔_1 = 색깔_문법_1.search(분리[0])
  64. 색깔_문법_2 = re.compile("^(#[0-9a-f-A-F]{3})\s(.*)$", re.DOTALL)
  65. 색깔_2 = 색깔_문법_2.search(분리[0])
  66. 색깔_문법_3 = re.compile("^#(\w+)\s(.*)$", re.DOTALL)
  67. 색깔_3 = 색깔_문법_3.search(분리[0])
  68. 배경색_문법_1 = re.compile("^@([0-9a-f-A-F]{6})\s(.*)$", re.DOTALL)
  69. 배경색_1 = 배경색_문법_1.search(분리[0])
  70. 배경색_문법_2 = re.compile("^@([0-9a-f-A-F]{3})\s(.*)$", re.DOTALL)
  71. 배경색_2 = 배경색_문법_2.search(분리[0])
  72. 배경색_문법_3 = re.compile("^@(\w+)\s(.*)$", re.DOTALL)
  73. 배경색_3 = 배경색_문법_3.search(분리[0])
  74. 틀_제외_문법 = re.compile("^#!noin\s(.*)$", re.DOTALL)
  75. 틀_제외 = 틀_제외_문법.search(분리[0])
  76. DIV_문법 = re.compile("^#!wiki\sstyle=&quot;((?:(?!&quot;|\n).)*)&quot;\n?\s\n(.*)$", re.DOTALL)
  77. DIV = DIV_문법.search(분리[0])
  78. HTML_문법 = re.compile("^#!html\s(.*)$", re.DOTALL)
  79. HTML = HTML_문법.search(분리[0])
  80. 접기_문법 = re.compile("^#!folding\s((?:(?!\n).)*)\n?\s\n(.*)$", re.DOTALL)
  81. 접기 = 접기_문법.search(분리[0])
  82. if(크게):
  83. 결과 = 크게.groups()
  84. 데이터 = 문법_컴파일.sub('<span class="font-size-' + 결과[0] + '">' + 결과[1] + '</span>', 데이터, 1)
  85. elif(작게):
  86. 결과 = 작게.groups()
  87. 데이터 = 문법_컴파일.sub('<span class="font-size-small-' + 결과[0] + '">' + 결과[1] + '</span>', 데이터, 1)
  88. elif(색깔_1):
  89. 결과 = 색깔_1.groups()
  90. data = 문법_컴파일.sub('<span style="color:' + 결과[0] + '">' + 결과[1] + '</span>', 데이터, 1)
  91. elif(색깔_2):
  92. 결과 = 색깔_2.groups()
  93. 데이터 = 문법_컴파일.sub('<span style="color:' + 결과[0] + '">' + 결과[1] + '</span>', 데이터, 1)
  94. elif(색깔_3):
  95. 결과 = 색깔_3.groups()
  96. 데이터 = 문법_컴파일.sub('<span style="color:' + 결과[0] + '">' + 결과[1] + '</span>', 데이터, 1)
  97. elif(배경색_1):
  98. 결과 = 배경색_1.groups()
  99. 데이터 = 문법_컴파일.sub('<span style="background:#' + 결과[0] + '">' + 결과[1] + '</span>', 데이터, 1)
  100. elif(배경색_2):
  101. 결과 = 배경색_2.groups()
  102. 데이터 = 문법_컴파일.sub('<span style="background:#' + 결과[0] + '">' + 결과[1] + '</span>', 데이터, 1)
  103. elif(배경색_3):
  104. 결과 = 배경색_3.groups()
  105. 데이터 = 문법_컴파일.sub('<span style="background:' + 결과[0] + '">' + 결과[1] + '</span>', 데이터, 1)
  106. elif(DIV):
  107. 결과 = DIV.groups()
  108. 데이터 = 문법_컴파일.sub('<div style="' + 결과[0] + '">' + 결과[1] + '</div>', 데이터, 1)
  109. elif(HTML):
  110. 결과 = HTML.groups()
  111. 데이터 = 문법_컴파일.sub(결과[0], 데이터, 1)
  112. elif(접기):
  113. 결과 = 접기.groups()
  114. 데이터 = 문법_컴파일.sub("<div>" + 결과[0] + "<span style='float:right;'><div id='folding_" + str(접기_숫자 + 1) + "' style='display:block;'>[<a href='javascript:void(0);' onclick='var f=document.getElementById(\"folding_" + str(접기_숫자) + "\");var s=f.style.display==\"block\";f.style.display=s?\"none\":\"block\";this.className=s?\"\":\"opened\";var f=document.getElementById(\"folding_" + str(접기_숫자 + 1) + "\");var s=f.style.display==\"none\";f.style.display=s?\"block\":\"none\";var f=document.getElementById(\"folding_" + str(접기_숫자 + 2) + "\");var s=f.style.display==\"block\";f.style.display=s?\"none\":\"block\";'>펼치기</a>]</div><div id='folding_" + str(접기_숫자 + 2) + "' style='display:none;'>[<a href='javascript:void(0);' onclick='var f=document.getElementById(\"folding_" + str(접기_숫자) + "\");var s=f.style.display==\"block\";f.style.display=s?\"none\":\"block\";this.className=s?\"\":\"opened\";var f=document.getElementById(\"folding_" + str(접기_숫자 + 1) + "\");var s=f.style.display==\"none\";f.style.display=s?\"block\":\"none\";var f=document.getElementById(\"folding_" + str(접기_숫자 + 2) + "\");var s=f.style.display==\"block\";f.style.display=s?\"none\":\"block\";'>접기</a>]</div></a></span><div id='folding_" + str(접기_숫자) + "' style='display:none;'><br>" + 결과[1] + "</div></div>", 데이터, 1)
  115. 접기_숫자 += 3
  116. elif(HTML):
  117. 결과 = HTML.groups()
  118. 데이터 = 문법_컴파일.sub(결과[0], 데이터, 1)
  119. elif(틀_제외):
  120. if(틀 == True):
  121. 데이터 = 문법_컴파일.sub("", 데이터, 1)
  122. else:
  123. 결과 = 틀_제외.groups()
  124. 데이터 = 문법_컴파일.sub(결과[0], 데이터, 1)
  125. else:
  126. 데이터 = 문법_컴파일.sub('<code>' + 분리[0] + '</code>', 데이터, 1)
  127. else:
  128. break
  129. while(True):
  130. 문법_컴파일 = re.compile("<code>(((?!<\/code>).)*)<\/code>", re.DOTALL)
  131. 있나 = 문법_컴파일.search(데이터)
  132. if(있나):
  133. 결과 = 있나.groups()
  134. 중간_데이터 = re.sub("<\/span>", "}}}", 결과[0])
  135. 중간_데이터 = re.sub("<\/div>", "}}}", 중간_데이터)
  136. 중간_데이터 = re.sub('<span class="font\-size\-(?P<in>[1-6])">', "{{{+\g<in> ", 중간_데이터)
  137. 중간_데이터 = re.sub('<span class="font\-size\-small\-(?P<in>[1-6])">', "{{{-\g<in> ", 중간_데이터)
  138. 중간_데이터 = re.sub('<span style="color:(?:#)?(?P<in>[^"]*)">', "{{{#\g<in> ", 중간_데이터)
  139. 중간_데이터 = re.sub('<span style="background:(?:#)?(?P<in>[^"]*)">', "{{{@\g<in> ", 중간_데이터)
  140. 중간_데이터 = re.sub('<div style="(?P<in>[^"]*)">', "{{{#!wiki style=&quot;\g<in>&quot;\n", 중간_데이터)
  141. 중간_데이터 = re.sub("(?P<in>.)", "<span>\g<in></span>", 중간_데이터)
  142. 데이터 = 문법_컴파일.sub(중간_데이터, 데이터, 1)
  143. else:
  144. break
  145. 데이터 = re.sub("<span>&</span><span>l</span><span>t</span><span>;</span>", "<span>&lt;</span>", 데이터)
  146. 데이터 = re.sub("<span>&</span><span>g</span><span>t</span><span>;</span>", "<span>&gt;</span>", 데이터)
  147. return (데이터, 접기_숫자)
  148. def 역링크_추가(이름, 링크, 값):
  149. DB_실행("select title from back where title = '" + DB_인코딩(링크) + "' and link = '" + DB_인코딩(이름) + "' and type = '" + 값 + "'")
  150. 있나 = DB_가져오기()
  151. if(not 있나):
  152. DB_실행("insert into back (title, link, type) value ('" + DB_인코딩(링크) + "', '" + DB_인코딩(이름) + "', 'include')")
  153. DB_갱신()
  154. def 분류_추가(이름, 링크):
  155. DB_실행("select title from cat where title = '" + DB_인코딩(링크) + "' and cat = '" + DB_인코딩(이름) + "'")
  156. 있나 = DB_가져오기()
  157. if(not 있나):
  158. DB_실행("insert into cat (title, cat) value ('" + DB_인코딩(링크) + "', '" + DB_인코딩(이름) + "')")
  159. DB_갱신()
  160. def 나무마크(title, data):
  161. data = HTML_파싱(data)
  162. 접기_숫자 = 0
  163. 임시_저장 = 중괄호_문법(data, 접기_숫자, False)
  164. data = 임시_저장[0]
  165. 접기_숫자 = 임시_저장[1]
  166. data = re.sub("\[anchor\((?P<in>[^\[\]]*)\)\]", '<span id="\g<in>"></span>', data)
  167. data = 세이브마크(data)
  168. while(True):
  169. m = re.search("\[include\(((?:(?!\)\]|,).)*)((?:,\s?(?:[^)]*))+)?\)\]", data)
  170. if(m):
  171. results = m.groups()
  172. if(results[0] == title):
  173. data = re.sub("\[include\(((?:(?!\)\]|,).)*)((?:,\s?(?:[^)]*))+)?\)\]", "<b>" + results[0] + "</b>", data, 1)
  174. else:
  175. DB_실행("select * from data where title = '" + DB_인코딩(results[0]) + "'")
  176. 틀_내용 = DB_가져오기()
  177. 역링크_추가(title, results[0], 'include')
  178. if(틀_내용):
  179. 틀_데이터 = 틀_내용[0]['data']
  180. 틀_데이터 = re.sub("\[include\(((?:(?!\)\]|,).)*)((?:,\s?(?:[^)]*))+)?\)\]", "", 틀_데이터)
  181. 틀_데이터 = HTML_파싱(틀_데이터)
  182. 틀_데이터 = 중괄호_문법(틀_데이터, 접기_숫자, True)[0]
  183. if(results[1]):
  184. a = results[1]
  185. while(True):
  186. g = re.search("([^= ,]*)\=([^,]*)", a)
  187. if(g):
  188. result = g.groups()
  189. 틀_데이터 = re.sub("@" + result[0] + "@", result[1], 틀_데이터)
  190. a = re.sub("([^= ,]*)\=([^,]*)", "", a, 1)
  191. else:
  192. break
  193. data = re.sub("\[include\(((?:(?!\)\]|,).)*)((?:,\s?(?:[^)]*))+)?\)\]", '\n#nobr#<div>' + 틀_데이터 + '</div>\n#nobr#', data, 1)
  194. else:
  195. data = re.sub("\[include\(((?:(?!\)\]|,).)*)((?:,\s?(?:[^)]*))+)?\)\]", "<a class=\"not_thing\" href=\"" + URL_인코딩(results[0]) + "\">" + results[0] + "</a>", data, 1)
  196. else:
  197. break
  198. while(True):
  199. m = re.search('^#(?:redirect|넘겨주기)\s([^\n]*)', data)
  200. if(m):
  201. results = m.groups()
  202. aa = re.search("^(.*)(#(?:.*))$", results[0])
  203. if(aa):
  204. results = aa.groups()
  205. data = re.sub('^#(?:redirect|넘겨주기)\s([^\n]*)', '<meta http-equiv="refresh" content="0;url=/w/' + URL_인코딩(results[0]) + '/from/' + URL_인코딩(title) + results[1] + '" />', data, 1)
  206. else:
  207. data = re.sub('^#(?:redirect|넘겨주기)\s([^\n]*)', '<meta http-equiv="refresh" content="0;url=/w/' + URL_인코딩(results[0]) + '/from/' + URL_인코딩(title) + '" />', data, 1)
  208. 역링크_추가(title, results[0], 'redirect')
  209. else:
  210. break
  211. data = '\n' + data + '\n'
  212. while(True):
  213. m = re.search("\n&gt;\s?((?:[^\n]*)(?:(?:(?:(?:\n&gt;\s?)(?:[^\n]*))+)?))", data)
  214. if(m):
  215. result = m.groups()
  216. blockquote = result[0]
  217. blockquote = re.sub("\n&gt;\s?", "\n", blockquote)
  218. data = re.sub("\n&gt;\s?((?:[^\n]*)(?:(?:(?:(?:\n&gt;\s?)(?:[^\n]*))+)?))", "\n<blockquote>" + blockquote + "</blockquote>", data, 1)
  219. else:
  220. break
  221. m = re.search('\[목차\]', data)
  222. if(not m):
  223. data = re.sub("(?P<in>(={1,6})\s?([^=]*)\s?(?:={1,6})(?:\s+)?\n)", "[목차]\n\g<in>", data, 1)
  224. data = re.sub("(\n)(?P<in>\r\n(={1,6})\s?([^=]*)\s?(?:={1,6})(?:\s+)?\n)", "\g<in>", data)
  225. i = 0
  226. h0c = 0
  227. h1c = 0
  228. h2c = 0
  229. h3c = 0
  230. h4c = 0
  231. h5c = 0
  232. last = 0
  233. rtoc = '<div id="toc"><span id="toc-name">목차</span><br><br>'
  234. while(True):
  235. i = i + 1
  236. m = re.search('(={1,6})\s?([^=]*)\s?(?:={1,6})(?:\s+)?\n', data)
  237. if(m):
  238. result = m.groups()
  239. wiki = len(result[0])
  240. if(last < wiki):
  241. last = wiki
  242. else:
  243. last = wiki
  244. if(wiki == 1):
  245. h1c = 0
  246. h2c = 0
  247. h3c = 0
  248. h4c = 0
  249. h5c = 0
  250. elif(wiki == 2):
  251. h2c = 0
  252. h3c = 0
  253. h4c = 0
  254. h5c = 0
  255. elif(wiki == 3):
  256. h3c = 0
  257. h4c = 0
  258. h5c = 0
  259. elif(wiki == 4):
  260. h4c = 0
  261. h5c = 0
  262. elif(wiki == 5):
  263. h5c = 0
  264. if(wiki == 1):
  265. h0c = h0c + 1
  266. elif(wiki == 2):
  267. h1c = h1c + 1
  268. elif(wiki == 3):
  269. h2c = h2c + 1
  270. elif(wiki == 4):
  271. h3c = h3c + 1
  272. elif(wiki == 5):
  273. h4c = h4c + 1
  274. else:
  275. h5c = h5c + 1
  276. toc = str(h0c) + '.' + str(h1c) + '.' + str(h2c) + '.' + str(h3c) + '.' + str(h4c) + '.' + str(h5c) + '.'
  277. toc = re.sub("(?P<in>[0-9]0(?:[0]*)?)\.", '\g<in>#.', toc)
  278. toc = re.sub("0\.", '', toc)
  279. toc = re.sub("#\.", '.', toc)
  280. toc = re.sub("\.$", '', toc)
  281. rtoc = rtoc + '<a href="#s-' + toc + '">' + toc + '</a>. ' + result[1] + '<br>'
  282. c = re.sub(" $", "", result[1])
  283. d = c
  284. c = re.sub("\[\[(([^|]*)\|)?(?P<in>[^\]]*)\]\]", "\g<in>", c)
  285. data = re.sub('(={1,6})\s?([^=]*)\s?(?:={1,6})(?:\s+)?\n', '<h' + str(wiki) + ' id="' + c + '"><a href="#toc" id="s-' + toc + '">' + toc + '.</a> ' + d + ' <span style="font-size:11px;">[<a href="/edit/' + URL_인코딩(title) + '/section/' + str(i) + '">편집</a>]</span></h' + str(wiki) + '>', data, 1);
  286. else:
  287. rtoc = rtoc + '</div>'
  288. break
  289. data = re.sub("\[목차\]", rtoc, data)
  290. category = ''
  291. while(True):
  292. m = re.search("\[\[(분류:(?:(?:(?!\]\]).)*))\]\]", data)
  293. if(m):
  294. g = m.groups()
  295. if(not title == g[0]):
  296. 분류_추가(title, g[0])
  297. if(category == ''):
  298. DB_실행("select * from data where title = '" + DB_인코딩(g[0]) + "'")
  299. exists = DB_가져오기()
  300. if(exists):
  301. red = ""
  302. else:
  303. red = 'class="not_thing"'
  304. category = category + '<a ' + red + ' href="/w/' + URL_인코딩(g[0]) + '">' + re.sub("분류:", "", g[0]) + '</a>'
  305. else:
  306. DB_실행("select * from data where title = '" + DB_인코딩(g[0]) + "'")
  307. exists = DB_가져오기()
  308. if(exists):
  309. red = ""
  310. else:
  311. red = 'class="not_thing"'
  312. category = category + ' / ' + '<a ' + red + ' href="/w/' + URL_인코딩(g[0]) + '">' + re.sub("분류:", "", g[0]) + '</a>'
  313. data = re.sub("\[\[(분류:(?:(?:(?!\]\]).)*))\]\]", '', data, 1)
  314. else:
  315. break
  316. data = re.sub("'''(?P<in>.+?)'''(?!')", '<b>\g<in></b>', data)
  317. data = re.sub("''(?P<in>.+?)''(?!')", '<i>\g<in></i>', data)
  318. data = re.sub('~~(?P<in>.+?)~~(?!~)', '<s>\g<in></s>', data)
  319. data = re.sub('--(?P<in>.+?)--(?!-)', '<s>\g<in></s>', data)
  320. data = re.sub('__(?P<in>.+?)__(?!_)', '<u>\g<in></u>', data)
  321. data = re.sub('\^\^(?P<in>.+?)\^\^(?!\^)', '<sup>\g<in></sup>', data)
  322. data = re.sub(',,(?P<in>.+?),,(?!,)', '<sub>\g<in></sub>', data)
  323. data = re.sub('&lt;math&gt;(?P<in>((?!&lt;math&gt;).)*)&lt;\/math&gt;', '$\g<in>$', data)
  324. data = re.sub('{{\|(?P<in>(?:(?:(?:(?!\|}}).)*)(?:\n?))+)\|}}', '<table><tbody><tr><td>\g<in></td></tr></tbody></table>', data)
  325. data = re.sub('\[ruby\((?P<in>[^\|]*)\|(?P<out>[^\)]*)\)\]', '<ruby>\g<in><rp>(</rp><rt>\g<out></rt><rp>)</rp></ruby>', data)
  326. data = re.sub("##\s?(?P<in>[^\n]*)\n", "<div style='display:none;'>\g<in></div>", data);
  327. while(True):
  328. m = re.search("\[\[파일:((?:(?!\]\]|\|).)*)(?:\|((?:(?!\]\]).)*))?\]\]", data)
  329. if(m):
  330. c = m.groups()
  331. if(c):
  332. if(c[1]):
  333. n = re.search("width=([^ \n&]*)", c[1])
  334. e = re.search("height=([^ \n&]*)", c[1])
  335. if(n):
  336. a = n.groups()
  337. width = a[0]
  338. else:
  339. width = ''
  340. if(e):
  341. b = e.groups()
  342. height = b[0]
  343. else:
  344. height = ''
  345. img = re.sub("\.(?P<in>[Jj][Pp][Gg]|[Pp][Nn][Gg]|[Gg][Ii][Ff]|[Jj][Pp][Ee][Gg])", "#\g<in>#", c[0])
  346. data = re.sub("\[\[파일:((?:(?!\]\]|\?).)*)(?:\?((?:(?!\]\]).)*))?\]\]", '<a href="/w/파일:' + img + '"><img src="/image/' + img + '" width="' + width + '" height="' + height + '"></a>', data, 1)
  347. else:
  348. img = re.sub("\.(?P<in>[Jj][Pp][Gg]|[Pp][Nn][Gg]|[Gg][Ii][Ff]|[Jj][Pp][Ee][Gg])", "#\g<in>#", c[0])
  349. data = re.sub("\[\[파일:((?:(?!\]\]|\?).)*)(?:\?((?:(?!\]\]).)*))?\]\]", "<a href='/w/파일:" + img + "'><img src='/image/" + img + "'></a>", data, 1)
  350. else:
  351. img = re.sub("\.(?P<in>[Jj][Pp][Gg]|[Pp][Nn][Gg]|[Gg][Ii][Ff]|[Jj][Pp][Ee][Gg])", "#\g<in>#", c[0])
  352. data = re.sub("\[\[파일:((?:(?!\]\]|\?).)*)(?:\?((?:(?!\]\]).)*))?\]\]", "<a href='/w/파일:" + img + "'><img src='/image/" + img + "'></a>", data, 1)
  353. if(not re.search("^파일:([^\n]*)", title)):
  354. 역링크_추가(title, '파일' + c[0], 'file')
  355. else:
  356. break
  357. data = re.sub("\[br\]",'<br>', data)
  358. while(True):
  359. 문법_컴파일 = re.compile("\[youtube\(((?:(?!,|\)\]).)*)(?:,(?:\s)?)?(?:width=((?:(?!,|\)\]).)*))?(?:,(?:\s)?)?(?:height=((?:(?!,|\)\]).)*))?\)\]")
  360. m = 문법_컴파일.search(data)
  361. if(m):
  362. result = m.groups()
  363. if(result[1]):
  364. if(result[2]):
  365. width = result[1]
  366. height = result[2]
  367. else:
  368. width = result[1]
  369. height = '315'
  370. elif(result[2]):
  371. height = result[2]
  372. width = '560'
  373. else:
  374. width = '560'
  375. height = '315'
  376. data = 문법_컴파일.sub('<iframe width="' + width + '" height="' + height + '" src="https://www.youtube.com/embed/' + result[0] + '" frameborder="0" allowfullscreen></iframe>', data, 1)
  377. else:
  378. break
  379. data = re.sub("\[\[(?::(?P<in>(?:분류|파일):(?:(?:(?!\]\]).)*)))\]\]", "[[\g<in>]]", data)
  380. while(True):
  381. m = re.search("\[\[(((?!\]\]).)*)\]\]", data)
  382. if(m):
  383. result = m.groups()
  384. a = re.search("((?:(?!\|).)*)\|(.*)", result[0])
  385. if(a):
  386. results = a.groups()
  387. aa = re.search("^(.*)(#(?:.*))$", results[0])
  388. if(aa):
  389. g = results[1]
  390. results = aa.groups()
  391. b = re.search("^http(?:s)?:\/\/", results[0])
  392. if(b):
  393. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<a class="out_link" href="' + results[0] + results[1] + '">' + g + '</a>', data, 1)
  394. else:
  395. if(results[0] == title):
  396. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<b>' + g + '</b>', data, 1)
  397. else:
  398. DB_실행("select title from data where title = '" + DB_인코딩(results[0]) + "'")
  399. 있나 = DB_가져오기()
  400. if(있나):
  401. 클래스 = ''
  402. else:
  403. 클래스 = 'not_thing'
  404. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<a title="' + results[0] + results[1] + '" class="' + 클래스 + '" href="/w/' + URL_인코딩(results[0]) + results[1] + '">' + g + '</a>', data, 1)
  405. 역링크_추가(title, results[0], '')
  406. else:
  407. b = re.search("^http(?:s)?:\/\/", results[0])
  408. if(b):
  409. c = re.search("(?:\.[Jj][Pp][Gg]|\.[Pp][Nn][Gg]|\.[Gg][Ii][Ff]|\.[Jj][Pp][Ee][Gg])", results[0])
  410. if(c):
  411. img = results[0]
  412. img = re.sub("\.(?P<in>[Jj][Pp][Gg]|[Pp][Nn][Gg]|[Gg][Ii][Ff]|[Jj][Pp][Ee][Gg])", "#\g<in>#", img)
  413. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<a class="out_link" href="' + img + '">' + results[1] + '</a>', data, 1)
  414. else:
  415. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<a class="out_link" href="' + results[0] + '">' + results[1] + '</a>', data, 1)
  416. else:
  417. if(results[0] == title):
  418. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<b>' + results[1] + '</b>', data, 1)
  419. else:
  420. DB_실행("select title from data where title = '" + DB_인코딩(results[0]) + "'")
  421. 있나 = DB_가져오기()
  422. if(있나):
  423. 클래스 = ''
  424. else:
  425. 클래스 = 'not_thing'
  426. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<a title="' + results[0] + '" class="' + 클래스 + '" href="/w/' + URL_인코딩(results[0]) + '">' + results[1] + '</a>', data, 1)
  427. 역링크_추가(title, results[0], '')
  428. else:
  429. aa = re.search("^(.*)(#(?:.*))$", result[0])
  430. if(aa):
  431. result = aa.groups()
  432. b = re.search("^http(?:s)?:\/\/", result[0])
  433. if(b):
  434. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<a class="out_link" href="' + result[0] + result[1] + '">' + result[0] + result[1] + '</a>', data, 1)
  435. else:
  436. if(result[0] == title):
  437. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<b>' + result[0] + result[1] + '</b>', data, 1)
  438. else:
  439. DB_실행("select title from data where title = '" + DB_인코딩(result[0]) + "'")
  440. 있나 = DB_가져오기()
  441. if(있나):
  442. 클래스 = ''
  443. else:
  444. 클래스 = 'not_thing'
  445. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<a href="/w/' + URL_인코딩(result[0]) + result[1] + '" class="' + 클래스 + '">' + result[0] + result[1] + '</a>', data, 1)
  446. 역링크_추가(title, result[0], '')
  447. else:
  448. b = re.search("^http(?:s)?:\/\/", result[0])
  449. if(b):
  450. c = re.search("(?:\.[Jj][Pp][Gg]|\.[Pp][Nn][Gg]|\.[Gg][Ii][Ff]|\.[Jj][Pp][Ee][Gg])", result[0])
  451. if(c):
  452. img = result[0]
  453. img = re.sub("\.(?P<in>[Jj][Pp][Gg]|[Pp][Nn][Gg]|[Gg][Ii][Ff]|[Jj][Pp][Ee][Gg])", "#\g<in>#", img)
  454. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<a class="out_link" href="' + img + '">' + img + '</a>', data, 1)
  455. else:
  456. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<a class="out_link" href="' + result[0] + '">' + result[0] + '</a>', data, 1)
  457. else:
  458. if(result[0] == title):
  459. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<b>' + result[0] + '</b>', data, 1)
  460. else:
  461. DB_실행("select title from data where title = '" + DB_인코딩(result[0]) + "'")
  462. 있나 = DB_가져오기()
  463. if(있나):
  464. 클래스 = ''
  465. else:
  466. 클래스 = 'not_thing'
  467. data = re.sub('\[\[(((?!\]\]).)*)\]\]', '<a href="/w/' + URL_인코딩(result[0]) + '" class="' + 클래스 + '">' + result[0] + '</a>', data, 1)
  468. 역링크_추가(title, result[0], '')
  469. else:
  470. break
  471. while(True):
  472. 문법_컴파일 = re.compile("(http(?:s)?:\/\/(?:(?:(?:(?!\.[Jj][Pp][Gg]|\.[Pp][Nn][Gg]|\.[Gg][Ii][Ff]|\.[Jj][Pp][Ee][Gg]|#[Jj][Pp][Gg]#|#[Pp][Nn][Gg]#|#[Gg][Ii][Ff]#|#[Jj][Pp][Ee][Gg]#|<\/(?:[^>]*)>).)*)(?:\.[Jj][Pp][Gg]|\.[Pp][Nn][Gg]|\.[Gg][Ii][Ff]|\.[Jj][Pp][Ee][Gg])))(?:(?:(?:\?)width=((?:[0-9]*)(?:px|%)?))?(?:(?:\?|&)height=((?:[0-9]*)(?:px|%)?))?)")
  473. m = 문법_컴파일.search(data)
  474. if(m):
  475. result = m.groups()
  476. if(result[1]):
  477. if(result[2]):
  478. width = result[1]
  479. height = result[2]
  480. else:
  481. width = result[1]
  482. height = ''
  483. elif(result[2]):
  484. height = result[2]
  485. width = ''
  486. else:
  487. width = ''
  488. height = ''
  489. c = result[0]
  490. c = re.sub("\.(?P<in>[Jj][Pp][Gg]|[Pp][Nn][Gg]|[Gg][Ii][Ff]|[Jj][Pp][Ee][Gg])", "#\g<in>#", c)
  491. data = 문법_컴파일.sub("<img width='" + width + "' height='" + height + "' src='" + c + "'>", data, 1)
  492. else:
  493. break
  494. while(True):
  495. m = re.search("((?:(?:( +)\*\s(?:[^\n]*))\n?)+)", data)
  496. if(m):
  497. result = m.groups()
  498. end = str(result[0])
  499. while(True):
  500. isspace = re.search("( +)\*\s([^\n]*)", end)
  501. if(isspace):
  502. spacebar = isspace.groups()
  503. up = len(spacebar[0]) * 20
  504. end = re.sub("( +)\*\s([^\n]*)", "<li style='margin-left:" + str(up) + "px'>" + spacebar[1] + "</li>", end, 1)
  505. else:
  506. break
  507. end = re.sub("\n", '', end)
  508. data = re.sub("(?:(?:(?:( +)\*\s([^\n]*))\n?)+)", '<ul id="list">' + end + '</ul>', data, 1)
  509. else:
  510. break
  511. data = re.sub('\[date\]', 시간(), data)
  512. data = re.sub("#(?P<in>[Jj][Pp][Gg]|[Pp][Nn][Gg]|[Gg][Ii][Ff]|[Jj][Pp][Ee][Gg])#", ".\g<in>", data)
  513. data = re.sub("-{4,11}", "<hr>", data)
  514. while(True):
  515. b = re.search("\n( +)", data)
  516. if(b):
  517. result = b.groups()
  518. up = re.sub(' ', '<span id="in"></span>', result[0])
  519. data = re.sub("\n( +)", '<br>' + up, data, 1)
  520. else:
  521. break
  522. a = 1
  523. tou = "<hr id='footnote'><div class='wiki-macro-footnote'><br>"
  524. while(True):
  525. b = re.search("\[\*([^\s]*)\s(((?!\]).)*)\]", data)
  526. if(b):
  527. results = b.groups()
  528. if(results[0]):
  529. c = results[1]
  530. c = re.sub("<(?:[^>]*)>", '', c)
  531. tou = tou + "<span class='footnote-list'><a href=\"#rfn-" + str(a) + "\" id=\"fn-" + str(a) + "\">[" + results[0] + "]</a> " + results[1] + "</span><br>"
  532. data = re.sub("\[\*([^\s]*)\s(((?!\]).)*)\]", "<sup><a class=\"footnotes\" title=\"" + c + "\" id=\"rfn-" + str(a) + "\" href=\"#fn-" + str(a) + "\">[" + results[0] + "]</a></sup>", data, 1)
  533. else:
  534. c = results[1]
  535. c = re.sub("<(?:[^>]*)>", '', c)
  536. tou = tou + "<span class='footnote-list'><a href=\"#rfn-" + str(a) + "\" id=\"fn-" + str(a) + "\">[" + str(a) + "]</a> " + results[1] + "</span><br>"
  537. data = re.sub("\[\*([^\s]*)\s(((?!\]).)*)\]", '<sup><a class="footnotes" title="' + c + '" id="rfn-' + str(a) + '" href="#fn-' + str(a) + '">[' + str(a) + ']</a></sup>', data, 1)
  538. a = a + 1
  539. else:
  540. tou = tou + '</div>'
  541. if(tou == "<hr id='footnote'><div class='wiki-macro-footnote'><br></div>"):
  542. tou = ""
  543. break
  544. data = re.sub("\[각주\](?:(?:<br>| |\r|\n)+)?$", "", data)
  545. data = re.sub("(?:(?:<br>| |\r|\n)+)$", "", data)
  546. data = re.sub("\[각주\]", "<br>" + tou, data)
  547. data = data + tou
  548. if(category):
  549. data = data + '<div style="width:100%;border: 1px solid #777;padding: 5px;margin-top: 1em;">분류: ' + category + '</div>'
  550. data = re.sub("(?:\|\|\r\n)", "#table#<nobr>", data)
  551. while(True):
  552. 있나 = re.search("(\|\|(?:(?:(?:(?:(?!\|\|).)*)(?:\n?))+))", data)
  553. if(있나):
  554. 분리 = 있나.groups()
  555. 중간_내용 = re.sub("\|\|", "#table#", 분리[0])
  556. 중간_내용 = re.sub("\r\n", "<br>", 중간_내용)
  557. data = re.sub("(\|\|((?:(?:(?:(?!\|\|).)*)(?:\n?))+))", 중간_내용, data, 1)
  558. else:
  559. break
  560. data = re.sub("#table#", "||", data)
  561. data = re.sub("<nobr>", "\r\n", data)
  562. while(True):
  563. m = re.search("(\|\|(?:(?:(?:.*)\n?)\|\|)+)", data)
  564. if(m):
  565. results = m.groups()
  566. table = results[0]
  567. while(True):
  568. a = re.search("^(\|\|(?:(?:\|\|)+)?)((?:&lt;(?:(?:(?!&gt;).)*)&gt;)+)?", table)
  569. if(a):
  570. row = ''
  571. cel = ''
  572. celstyle = ''
  573. rowstyle = ''
  574. alltable = ''
  575. result = a.groups()
  576. if(result[1]):
  577. alltable = 'style="'
  578. celstyle = 'style="'
  579. rowstyle = 'style="'
  580. q = re.search("&lt;table\s?width=((?:(?!&gt;).)*)&gt;", result[1])
  581. w = re.search("&lt;table\s?height=((?:(?!&gt;).)*)&gt;", result[1])
  582. e = re.search("&lt;table\s?align=((?:(?!&gt;).)*)&gt;", result[1])
  583. if(q):
  584. resultss = q.groups()
  585. alltable = alltable + 'width:' + resultss[0] + ';'
  586. if(w):
  587. resultss = w.groups()
  588. alltable = alltable + 'height:' + resultss[0] + ';'
  589. if(e):
  590. resultss = e.groups()
  591. if(resultss[0] == 'right'):
  592. alltable = alltable + 'margin-left:auto;'
  593. elif(resultss[0] == 'center'):
  594. alltable = alltable + 'margin:auto;'
  595. else:
  596. alltable = alltable + 'margin-right:auto;'
  597. ee = re.search("&lt;table\s?textalign=((?:(?!&gt;).)*)&gt;", result[1])
  598. if(ee):
  599. resultss = ee.groups()
  600. if(resultss[0] == 'right'):
  601. alltable = alltable + 'text-align:right;'
  602. elif(resultss[0] == 'center'):
  603. alltable = alltable + 'text-align:center;'
  604. else:
  605. alltable = alltable + 'text-align:left;'
  606. r = re.search("&lt;-((?:(?!&gt;).)*)&gt;", result[1])
  607. if(r):
  608. resultss = r.groups()
  609. cel = 'colspan="' + resultss[0] + '"'
  610. else:
  611. cel = 'colspan="' + str(round(len(result[0]) / 2)) + '"'
  612. t = re.search("&lt;\|((?:(?!&gt;).)*)&gt;", result[1])
  613. if(t):
  614. resultss = t.groups()
  615. row = 'rowspan="' + resultss[0] + '"'
  616. ba = re.search("&lt;rowbgcolor=(#[0-9a-f-A-F]{6})&gt;", result[1])
  617. bb = re.search("&lt;rowbgcolor=(#[0-9a-f-A-F]{3})&gt;", result[1])
  618. bc = re.search("&lt;rowbgcolor=(\w+)&gt;", result[1])
  619. if(ba):
  620. resultss = ba.groups()
  621. rowstyle = rowstyle + 'background:' + resultss[0] + ';'
  622. elif(bb):
  623. resultss = bb.groups()
  624. rowstyle = rowstyle + 'background:' + resultss[0] + ';'
  625. elif(bc):
  626. resultss = bc.groups()
  627. rowstyle = rowstyle + 'background:' + resultss[0] + ';'
  628. z = re.search("&lt;table\s?bordercolor=(#[0-9a-f-A-F]{6})&gt;", result[1])
  629. x = re.search("&lt;table\s?bordercolor=(#[0-9a-f-A-F]{3})&gt;", result[1])
  630. c = re.search("&lt;table\s?bordercolor=(\w+)&gt;", result[1])
  631. if(z):
  632. resultss = z.groups()
  633. alltable = alltable + 'border:' + resultss[0] + ' 2px solid;'
  634. elif(x):
  635. resultss = x.groups()
  636. alltable = alltable + 'border:' + resultss[0] + ' 2px solid;'
  637. elif(c):
  638. resultss = c.groups()
  639. alltable = alltable + 'border:' + resultss[0] + ' 2px solid;'
  640. aq = re.search("&lt;table\s?bgcolor=(#[0-9a-f-A-F]{6})&gt;", result[1])
  641. aw = re.search("&lt;table\s?bgcolor=(#[0-9a-f-A-F]{3})&gt;", result[1])
  642. ae = re.search("&lt;table\s?bgcolor=(\w+)&gt;", result[1])
  643. if(aq):
  644. resultss = aq.groups()
  645. alltable = alltable + 'background:' + resultss[0] + ';'
  646. elif(aw):
  647. resultss = aw.groups()
  648. alltable = alltable + 'background:' + resultss[0] + ';'
  649. elif(ae):
  650. resultss = ae.groups()
  651. alltable = alltable + 'background:' + resultss[0] + ';'
  652. j = re.search("&lt;bgcolor=(#[0-9a-f-A-F]{6})&gt;", result[1])
  653. k = re.search("&lt;bgcolor=(#[0-9a-f-A-F]{3})&gt;", result[1])
  654. l = re.search("&lt;bgcolor=(\w+)&gt;", result[1])
  655. if(j):
  656. resultss = j.groups()
  657. celstyle = celstyle + 'background:' + resultss[0] + ';'
  658. elif(k):
  659. resultss = k.groups()
  660. celstyle = celstyle + 'background:' + resultss[0] + ';'
  661. elif(l):
  662. resultss = l.groups()
  663. celstyle = celstyle + 'background:' + resultss[0] + ';'
  664. aa = re.search("&lt;(#[0-9a-f-A-F]{6})&gt;", result[1])
  665. ab = re.search("&lt;(#[0-9a-f-A-F]{3})&gt;", result[1])
  666. ac = re.search("&lt;(\w+)&gt;", result[1])
  667. if(aa):
  668. resultss = aa.groups()
  669. celstyle = celstyle + 'background:' + resultss[0] + ';'
  670. elif(ab):
  671. resultss = ab.groups()
  672. celstyle = celstyle + 'background:' + resultss[0] + ';'
  673. elif(ac):
  674. resultss = ac.groups()
  675. celstyle = celstyle + 'background:' + resultss[0] + ';'
  676. qa = re.search("&lt;width=((?:(?!&gt;).)*)&gt;", result[1])
  677. qb = re.search("&lt;height=((?:(?!&gt;).)*)&gt;", result[1])
  678. if(qa):
  679. resultss = qa.groups()
  680. celstyle = celstyle + 'width:' + resultss[0] + ';'
  681. if(qb):
  682. resultss = qb.groups()
  683. celstyle = celstyle + 'height:' + resultss[0] + ';'
  684. i = re.search("&lt;\)&gt;", result[1])
  685. o = re.search("&lt;:&gt;", result[1])
  686. p = re.search("&lt;\(&gt;", result[1])
  687. if(i):
  688. celstyle = celstyle + 'text-align:right;'
  689. elif(o):
  690. celstyle = celstyle + 'text-align:center;'
  691. elif(p):
  692. celstyle = celstyle + 'text-align:left;'
  693. alltable = alltable + '"'
  694. celstyle = celstyle + '"'
  695. rowstyle = rowstyle + '"'
  696. table = re.sub("^(\|\|(?:(?:\|\|)+)?)((?:&lt;(?:(?:(?!&gt;).)*)&gt;)+)?", "<table " + alltable + "><tbody><tr " + rowstyle + "><td " + cel + " " + row + " " + celstyle + ">", table, 1)
  697. else:
  698. cel = 'colspan="' + str(round(len(result[0]) / 2)) + '"'
  699. table = re.sub("^(\|\|(?:(?:\|\|)+)?)((?:&lt;(?:(?:(?!&gt;).)*)&gt;)+)?", "<table><tbody><tr><td " + cel + ">", table, 1)
  700. else:
  701. break
  702. table = re.sub("\|\|$", "</td></tr></tbody></table>", table)
  703. while(True):
  704. b = re.search("\|\|\r\n(\|\|(?:(?:\|\|)+)?)((?:&lt;(?:(?:(?!&gt;).)*)&gt;)+)?", table)
  705. if(b):
  706. row = ''
  707. cel = ''
  708. celstyle = ''
  709. rowstyle = ''
  710. result = b.groups()
  711. if(result[1]):
  712. celstyle = 'style="'
  713. rowstyle = 'style="'
  714. r = re.search("&lt;-((?:(?!&gt;).)*)&gt;", result[1])
  715. if(r):
  716. resultss = r.groups()
  717. cel = 'colspan="' + resultss[0] + '"'
  718. else:
  719. cel = 'colspan="' + str(round(len(result[0]) / 2)) + '"'
  720. t = re.search("&lt;\|((?:(?!&gt;).)*)&gt;", result[1])
  721. if(t):
  722. resultss = t.groups()
  723. row = 'rowspan="' + resultss[0] + '"'
  724. ba = re.search("&lt;rowbgcolor=(#[0-9a-f-A-F]{6})&gt;", result[1])
  725. bb = re.search("&lt;rowbgcolor=(#[0-9a-f-A-F]{3})&gt;", result[1])
  726. bc = re.search("&lt;rowbgcolor=(\w+)&gt;", result[1])
  727. if(ba):
  728. resultss = ba.groups()
  729. rowstyle = rowstyle + 'background:' + resultss[0] + ';'
  730. elif(bb):
  731. resultss = bb.groups()
  732. rowstyle = rowstyle + 'background:' + resultss[0] + ';'
  733. elif(bc):
  734. resultss = bc.groups()
  735. rowstyle = rowstyle + 'background:' + resultss[0] + ';'
  736. j = re.search("&lt;bgcolor=(#[0-9a-f-A-F]{6})&gt;", result[1])
  737. k = re.search("&lt;bgcolor=(#[0-9a-f-A-F]{3})&gt;", result[1])
  738. l = re.search("&lt;bgcolor=(\w+)&gt;", result[1])
  739. if(j):
  740. resultss = j.groups()
  741. celstyle = celstyle + 'background:' + resultss[0] + ';'
  742. elif(k):
  743. resultss = k.groups()
  744. celstyle = celstyle + 'background:' + resultss[0] + ';'
  745. elif(l):
  746. resultss = l.groups()
  747. celstyle = celstyle + 'background:' + resultss[0] + ';'
  748. aa = re.search("&lt;(#[0-9a-f-A-F]{6})&gt;", result[1])
  749. ab = re.search("&lt;(#[0-9a-f-A-F]{3})&gt;", result[1])
  750. ac = re.search("&lt;(\w+)&gt;", result[1])
  751. if(aa):
  752. resultss = aa.groups()
  753. celstyle = celstyle + 'background:' + resultss[0] + ';'
  754. elif(ab):
  755. resultss = ab.groups()
  756. celstyle = celstyle + 'background:' + resultss[0] + ';'
  757. elif(ac):
  758. resultss = ac.groups()
  759. celstyle = celstyle + 'background:' + resultss[0] + ';'
  760. qa = re.search("&lt;width=((?:(?!&gt;).)*)&gt;", result[1])
  761. qb = re.search("&lt;height=((?:(?!&gt;).)*)&gt;", result[1])
  762. if(qa):
  763. resultss = qa.groups()
  764. celstyle = celstyle + 'width:' + resultss[0] + ';'
  765. if(qb):
  766. resultss = qb.groups()
  767. celstyle = celstyle + 'height:' + resultss[0] + ';'
  768. i = re.search("&lt;\)&gt;", result[1])
  769. o = re.search("&lt;:&gt;", result[1])
  770. p = re.search("&lt;\(&gt;", result[1])
  771. if(i):
  772. celstyle = celstyle + 'text-align:right;'
  773. elif(o):
  774. celstyle = celstyle + 'text-align:center;'
  775. elif(p):
  776. celstyle = celstyle + 'text-align:left;'
  777. celstyle = celstyle + '"'
  778. rowstyle = rowstyle + '"'
  779. table = re.sub("\|\|\r\n(\|\|(?:(?:\|\|)+)?)((?:&lt;(?:(?:(?!&gt;).)*)&gt;)+)?", "</td></tr><tr " + rowstyle + "><td " + cel + " " + row + " " + celstyle + ">", table, 1)
  780. else:
  781. cel = 'colspan="' + str(round(len(result[0]) / 2)) + '"'
  782. table = re.sub("\|\|\r\n(\|\|(?:(?:\|\|)+)?)((?:&lt;(?:(?:(?!&gt;).)*)&gt;)+)?", "</td></tr><tr><td " + cel + ">", table, 1)
  783. else:
  784. break
  785. while(True):
  786. c = re.search("(\|\|(?:(?:\|\|)+)?)((?:&lt;(?:(?:(?!&gt;).)*)&gt;)+)?", table)
  787. if(c):
  788. row = ''
  789. cel = ''
  790. celstyle = ''
  791. result = c.groups()
  792. if(result[1]):
  793. celstyle = 'style="'
  794. r = re.search("&lt;-((?:(?!&gt;).)*)&gt;", result[1])
  795. if(r):
  796. resultss = r.groups()
  797. cel = 'colspan="' + resultss[0] + '"';
  798. else:
  799. cel = 'colspan="' + str(round(len(result[0]) / 2)) + '"'
  800. t = re.search("&lt;\|((?:(?!&gt;).)*)&gt;", result[1])
  801. if(t):
  802. resultss = t.groups()
  803. row = 'rowspan="' + resultss[0] + '"';
  804. j = re.search("&lt;bgcolor=(#[0-9a-f-A-F]{6})&gt;", result[1])
  805. k = re.search("&lt;bgcolor=(#[0-9a-f-A-F]{3})&gt;", result[1])
  806. l = re.search("&lt;bgcolor=(\w+)&gt;", result[1])
  807. if(j):
  808. resultss = j.groups()
  809. celstyle = celstyle + 'background:' + resultss[0] + ';'
  810. elif(k):
  811. resultss = k.groups()
  812. celstyle = celstyle + 'background:' + resultss[0] + ';'
  813. elif(l):
  814. resultss = l.groups()
  815. celstyle = celstyle + 'background:' + resultss[0] + ';'
  816. aa = re.search("&lt;(#[0-9a-f-A-F]{6})&gt;", result[1])
  817. ab = re.search("&lt;(#[0-9a-f-A-F]{3})&gt;", result[1])
  818. ac = re.search("&lt;(\w+)&gt;", result[1])
  819. if(aa):
  820. resultss = aa.groups()
  821. celstyle = celstyle + 'background:' + resultss[0] + ';'
  822. elif(ab):
  823. resultss = ab.groups()
  824. celstyle = celstyle + 'background:' + resultss[0] + ';'
  825. elif(ac):
  826. resultss = ac.groups()
  827. celstyle = celstyle + 'background:' + resultss[0] + ';'
  828. qa = re.search("&lt;width=((?:(?!&gt;).)*)&gt;", result[1])
  829. qb = re.search("&lt;height=((?:(?!&gt;).)*)&gt;", result[1])
  830. if(qa):
  831. resultss = qa.groups()
  832. celstyle = celstyle + 'width:' + resultss[0] + ';'
  833. if(qb):
  834. resultss = qb.groups()
  835. celstyle = celstyle + 'height:' + resultss[0] + ';'
  836. i = re.search("&lt;\)&gt;", result[1])
  837. o = re.search("&lt;:&gt;", result[1])
  838. p = re.search("&lt;\(&gt;", result[1])
  839. if(i):
  840. celstyle = celstyle + 'text-align:right;'
  841. elif(o):
  842. celstyle = celstyle + 'text-align:center;'
  843. elif(p):
  844. celstyle = celstyle + 'text-align:left;'
  845. celstyle = celstyle + '"'
  846. table = re.sub("(\|\|(?:(?:\|\|)+)?)((?:&lt;(?:(?:(?!&gt;).)*)&gt;)+)?", "</td><td " + cel + " " + row + " " + celstyle + ">", table, 1)
  847. else:
  848. cel = 'colspan="' + str(round(len(result[0]) / 2)) + '"'
  849. table = re.sub("(\|\|(?:(?:\|\|)+)?)((?:&lt;(?:(?:(?!&gt;).)*)&gt;)+)?", "</td><td " + cel + ">", table, 1)
  850. else:
  851. break
  852. data = re.sub("(\|\|(?:(?:(?:.*)\n?)\|\|)+)", table, data, 1)
  853. else:
  854. break
  855. data = re.sub("(\n#nobr#|#nobr#\n|#nobr#)", "", data)
  856. data = re.sub('<\/blockquote>((\r)?\n){2}<blockquote>', '</blockquote><br><blockquote>', data)
  857. data = re.sub('\n', '<br>', data)
  858. data = re.sub('^<br>', '', data)
  859. return data