mirror of
https://github.com/LCPQ/QUESTDB_website.git
synced 2025-01-12 14:08:28 +01:00
Update the fromXLSToLaTeX format to correctly handle double
This commit is contained in:
parent
2d8ed7b9f7
commit
7fe13a7600
@ -9,7 +9,7 @@ class dfbOptions(object):
|
|||||||
self.format="line"
|
self.format="line"
|
||||||
self.suffix=None
|
self.suffix=None
|
||||||
self.initialStates=defaultdict(lambda : state(1,1,"A_1"))
|
self.initialStates=defaultdict(lambda : state(1,1,"A_1"))
|
||||||
|
self.isDouble=False
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def readFromEnv(lateEnv):
|
def readFromEnv(lateEnv):
|
||||||
dfb_Opt=dfbOptions()
|
dfb_Opt=dfbOptions()
|
||||||
@ -42,4 +42,20 @@ class dfbOptions(object):
|
|||||||
else:
|
else:
|
||||||
mystate=state.fromString("1 "+vRArgs[0])
|
mystate=state.fromString("1 "+vRArgs[0])
|
||||||
dfb_Opt.initialStates[vOArgs[0]]=mystate
|
dfb_Opt.initialStates[vOArgs[0]]=mystate
|
||||||
|
dfbIsDouble=lateEnv.isDouble
|
||||||
|
if dfbIsDouble!=None:
|
||||||
|
dfbIsDouble=dfbIsDouble.expr
|
||||||
|
if type(dfbIsDouble) is TexCmd:
|
||||||
|
if len(dfbIsDouble.args)==0:
|
||||||
|
dfb_Opt.isDouble = True
|
||||||
|
elif len(dfbIsDouble.args)==1 and dfbIsDouble.args[0].type=="optional":
|
||||||
|
isDoubleStr=dfbIsDouble.args[0].value
|
||||||
|
if isDoubleStr == "true":
|
||||||
|
dfb_Opt.isDouble = True
|
||||||
|
elif isDoubleStr == "false":
|
||||||
|
isDouble = False
|
||||||
|
else:
|
||||||
|
raise ValueError("\isDouble must be 'true' or 'false'.")
|
||||||
|
else:
|
||||||
|
raise ValueError("Arguments error on '\isDouble'. Only one optional argument is supported.")
|
||||||
return dfb_Opt
|
return dfb_Opt
|
@ -6,50 +6,56 @@ from ...LaTeX import newCommand,extractMath
|
|||||||
import numpy as np
|
import numpy as np
|
||||||
import json
|
import json
|
||||||
import itertools
|
import itertools
|
||||||
def GetTypeFromAcronym(acronym):
|
|
||||||
acroDict={
|
|
||||||
"npi":r"n \rightarrow \pi^\star",
|
|
||||||
"ppi":r"\pi \rightarrow \pi^\star",
|
|
||||||
"n3s":r"n \rightarrow 3s",
|
|
||||||
"n3p":r"n \rightarrow 3p",
|
|
||||||
"dou":"double",
|
|
||||||
"p3s":r"\pi \rightarrow 3s",
|
|
||||||
"p3p":r"\pi \rightarrow 3p",
|
|
||||||
"spi":r"\sigma \rightarrow \pi^\star",
|
|
||||||
"CT":r"CT",
|
|
||||||
"non-d":None,
|
|
||||||
"n.d.":None
|
|
||||||
}
|
|
||||||
try:
|
|
||||||
return acroDict[acronym]
|
|
||||||
except KeyError as ex:
|
|
||||||
raise ValueError(f"Unrecognized acronym: {acronym}") from ex
|
|
||||||
def GetFullState(TexState,defaultDatatype=DataType.ABS,VR=None,typeAcronym=None,Soup=True):
|
|
||||||
datatype=defaultDatatype
|
|
||||||
lst=list(TexState)
|
|
||||||
if len(lst)>1 and lst[1].value=="F":
|
|
||||||
datatype=DataType.FLUO
|
|
||||||
statemath=str(list(lst[0].contents)[0])
|
|
||||||
resultstr=statemath
|
|
||||||
fulltype=[]
|
|
||||||
if datatype==DataType.FLUO:
|
|
||||||
resultstr+=r"[\mathrm{F}]"
|
|
||||||
if VR!=None:
|
|
||||||
fulltype.append(r"\mathrm{"+VR+"}")
|
|
||||||
if typeAcronym!=None:
|
|
||||||
_type=GetTypeFromAcronym(typeAcronym)
|
|
||||||
if _type!=None:
|
|
||||||
fulltype.append(_type)
|
|
||||||
if len(fulltype)>0:
|
|
||||||
resultstr+=" ("+";".join(fulltype)+")"
|
|
||||||
resultstr="$"+resultstr+"$"
|
|
||||||
if Soup:
|
|
||||||
return TexSoup(resultstr)
|
|
||||||
else:
|
|
||||||
return resultstr
|
|
||||||
|
|
||||||
@formatName("fromXLSToLaTeX")
|
@formatName("fromXLSToLaTeX")
|
||||||
class fromXLSToLaTeXHandler(formatHandlerBase):
|
class fromXLSToLaTeXHandler(formatHandlerBase):
|
||||||
|
def GetTypeFromAcronym(self,acronym):
|
||||||
|
ra = r'\rightarrow'
|
||||||
|
acroDict={
|
||||||
|
"npi":rf'n {ra} \pi^\star',
|
||||||
|
"ppi":rf'\pi {ra} \pi^\star',
|
||||||
|
"n3s":rf'n {ra} 3s',
|
||||||
|
"n3p":rf'n {ra} 3p',
|
||||||
|
"dou":"double",
|
||||||
|
"p3s":rf'\pi {ra} 3s',
|
||||||
|
"p3p":rf'\pi {ra} 3p',
|
||||||
|
"spi":rf'\sigma {ra} \pi^\star',
|
||||||
|
"CT":r'CT',
|
||||||
|
"non-d":None,
|
||||||
|
"n.d.":None
|
||||||
|
}
|
||||||
|
try:
|
||||||
|
value = acroDict[acronym]
|
||||||
|
if self.TexOps.isDouble and ra in value:
|
||||||
|
lr = [i.strip() for i in value.split(ra)]
|
||||||
|
return f'{lr[0]},{lr[0]} {ra} {lr[1]},{lr[1]}'
|
||||||
|
else:
|
||||||
|
return value
|
||||||
|
except KeyError as ex:
|
||||||
|
raise ValueError(f"Unrecognized acronym: {acronym}") from ex
|
||||||
|
def GetFullState(self,TexState,defaultDatatype=DataType.ABS,VR=None,typeAcronym=None,Soup=True):
|
||||||
|
datatype=defaultDatatype
|
||||||
|
lst=list(TexState)
|
||||||
|
if len(lst)>1 and lst[1].value=="F":
|
||||||
|
datatype=DataType.FLUO
|
||||||
|
statemath=str(list(lst[0].contents)[0])
|
||||||
|
resultstr=statemath
|
||||||
|
fulltype=[]
|
||||||
|
if datatype==DataType.FLUO:
|
||||||
|
resultstr+=r"[\mathrm{F}]"
|
||||||
|
if VR!=None:
|
||||||
|
fulltype.append(r"\mathrm{"+VR+"}")
|
||||||
|
if typeAcronym!=None:
|
||||||
|
_type=self.GetTypeFromAcronym(typeAcronym)
|
||||||
|
if _type!=None:
|
||||||
|
fulltype.append(_type)
|
||||||
|
if len(fulltype)>0:
|
||||||
|
resultstr+=" ("+";".join(fulltype)+")"
|
||||||
|
resultstr="$"+resultstr+"$"
|
||||||
|
if Soup:
|
||||||
|
return TexSoup(resultstr)
|
||||||
|
else:
|
||||||
|
return resultstr
|
||||||
|
|
||||||
def readFromTable(self,table):
|
def readFromTable(self,table):
|
||||||
datalist=list()
|
datalist=list()
|
||||||
subtablesRange=getSubtablesRange(table,firstindex=1,column=1)
|
subtablesRange=getSubtablesRange(table,firstindex=1,column=1)
|
||||||
@ -77,7 +83,7 @@ class fromXLSToLaTeXHandler(formatHandlerBase):
|
|||||||
methodname=str(methtex)
|
methodname=str(methtex)
|
||||||
mymethod=method(methodname,basis)
|
mymethod=method(methodname,basis)
|
||||||
methkey=json.dumps(mymethod.__dict__)
|
methkey=json.dumps(mymethod.__dict__)
|
||||||
mathstates=[GetFullState(table[i,4],VR=str(table[i,6]),typeAcronym=str(table[i,7]),Soup=True) for i in myrange]
|
mathstates=[self.GetFullState(table[i,4],VR=str(table[i,6]),typeAcronym=str(table[i,7]),Soup=True) for i in myrange]
|
||||||
finsts=dataFileBase.convertState(mathstates,initialState,default=self.TexOps.defaultType,commands=self.Commands)
|
finsts=dataFileBase.convertState(mathstates,initialState,default=self.TexOps.defaultType,commands=self.Commands)
|
||||||
for index,cell in enumerate(col[myrange]):
|
for index,cell in enumerate(col[myrange]):
|
||||||
if str(cell)!="":
|
if str(cell)!="":
|
||||||
|
Loading…
Reference in New Issue
Block a user