from ..formatHandlerBase import formatHandlerBase from ..formatName import formatName from ...data import dataFileBase,DataType,method,excitationValue,datafileSelector,getSubtablesRange,AbsDataFile,state from ...utils import getValFromCell, checkFloat from ...LaTeX import newCommand,extractMath from TexSoup import TexSoup import re @formatName("doubleTBE") class doubleTBEHandler(formatHandlerBase): def _readFromTableCore(self,table): datalist=list() subtablesMol=getSubtablesRange(table) for rangeMol in subtablesMol: data=AbsDataFile() data.molecule=str(table[rangeMol[0],0]) data.method=method("TBE","CBS") for mytrans in table[rangeMol]: mathsoup=extractMath(mytrans[1],Soup=True,commands=self.Commands) mytransdesc=str(mathsoup) infin=mytransdesc.split(r"\rightarrow") for i,item in enumerate(infin): m=re.match(r"^(?P\d)\\[,:;\s]\s*\^(?P\d)(?P\S*)",item.strip()) infin[i]=state(m.group("number"),m.group("multiplicity"),m.group("sym")) cell=mytrans[6] val,unsafe=getValFromCell(cell) data.excitations.append(excitationValue(infin[0],infin[1],val,isUnsafe=unsafe)) datalist.append(data) return datalist