forked from zzzmx-josh/chatgpt_academic
-
Notifications
You must be signed in to change notification settings - Fork 0
/
show_math.py
80 lines (77 loc) · 3.25 KB
/
show_math.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
# This program is written by: https://github.com/polarwinkel/mdtex2html
from latex2mathml.converter import convert as tex2mathml
import re
incomplete = '<font style="color:orange;" class="tooltip">⚠<span class="tooltiptext">formula incomplete</span></font>'
convError = '<font style="color:red" class="tooltip">⚠<span class="tooltiptext">LaTeX-convert-error</span></font>'
def convert(mdtex, extensions=[], splitParagraphs=True):
''' converts recursively the Markdown-LaTeX-mixture to HTML with MathML '''
found = False
# handle all paragraphs separately (prevents aftereffects)
if splitParagraphs:
parts = re.split("\n\n", mdtex)
result = ''
for part in parts:
result += convert(part, extensions, splitParagraphs=False)
return result
# find first $$-formula:
parts = re.split('\${2}', mdtex, 2)
if len(parts)>1:
found = True
result = convert(parts[0], extensions, splitParagraphs=False)+'\n'
try:
result += '<div class="blockformula">'+tex2mathml(parts[1])+'</div>\n'
except:
result += '<div class="blockformula">'+convError+'</div>'
if len(parts)==3:
result += convert(parts[2], extensions, splitParagraphs=False)
else:
result += '<div class="blockformula">'+incomplete+'</div>'
# else find first $-formulas:
else:
parts = re.split('\${1}', mdtex, 2)
if len(parts)>1 and not found:
found = True
try:
mathml = tex2mathml(parts[1])
except:
mathml = convError
if parts[0].endswith('\n\n') or parts[0]=='': # make sure textblock starts before formula!
parts[0]=parts[0]+'​'
if len(parts)==3:
result = convert(parts[0]+mathml+parts[2], extensions, splitParagraphs=False)
else:
result = convert(parts[0]+mathml+incomplete, extensions, splitParagraphs=False)
# else find first \[..\]-equation:
else:
parts = re.split(r'\\\[', mdtex, 1)
if len(parts)>1 and not found:
found = True
result = convert(parts[0], extensions, splitParagraphs=False)+'\n'
parts = re.split(r'\\\]', parts[1], 1)
try:
result += '<div class="blockformula">'+tex2mathml(parts[0])+'</div>\n'
except:
result += '<div class="blockformula">'+convError+'</div>'
if len(parts)==2:
result += convert(parts[1], extensions, splitParagraphs=False)
else:
result += '<div class="blockformula">'+incomplete+'</div>'
# else find first \(..\)-equation:
else:
parts = re.split(r'\\\(', mdtex, 1)
if len(parts)>1 and not found:
found = True
subp = re.split(r'\\\)', parts[1], 1)
try:
mathml = tex2mathml(subp[0])
except:
mathml = convError
if parts[0].endswith('\n\n') or parts[0]=='': # make sure textblock starts before formula!
parts[0]=parts[0]+'​'
if len(subp)==2:
result = convert(parts[0]+mathml+subp[1], extensions, splitParagraphs=False)
else:
result = convert(parts[0]+mathml+incomplete, extensions, splitParagraphs=False)
if not found:
result = mdtex
return result