import os import pandas as pd import gradio as gr # SNOMEDCT Download https://www.nlm.nih.gov/healthit/snomedct/us_edition.html # LOINC Download https://loinc.org/downloads/ # ECQM for Value Set Measures and Quality Reporting: https://vsac.nlm.nih.gov/download/ecqm?rel=20220505&res=eh_only.unique_vs.20220505.txt # SNOMED Nurse Subset https://www.nlm.nih.gov/healthit/snomedct/index.html?_gl=1*36x5pi*_ga*MTI0ODMyNjkxOS4xNjY1NTY3Mjcz*_ga_P1FPTH9PL4*MTY2Nzk4OTI1My41LjEuMTY2Nzk4OTY5Ni4wLjAuMA.. def MatchLOINC(name): basedir = os.path.dirname(__file__) pd.set_option("display.max_rows", None) data = pd.read_csv(f'LoincTableCore.csv') swith=data.loc[data['COMPONENT'].str.contains(name, case=False, na=False)] return swith def MatchLOINCPanelsandForms(name): basedir = os.path.dirname(__file__) data = pd.read_csv(f'PanelsAndForms.csv') swith=data.loc[data['ParentName'].str.contains(name, case=False, na=False)] return swith def MatchSNOMED(name): basedir = os.path.dirname(__file__) data = pd.read_csv(f'sct2_TextDefinition_Full-en_US1000124_20220901.txt',sep='\t') swith=data.loc[data['term'].str.contains(name, case=False, na=False)] #swith = data[data['term'].str.match(name)] return swith def MatchOMS(name): basedir = os.path.dirname(__file__) data = pd.read_csv(f'SnomedOMS.csv') swith=data.loc[data['SNOMED CT'].str.contains(name, case=False, na=False)] #swith = data[data['SNOMED CT'].str.match(name)] return swith with gr.Blocks() as demo: name = gr.Textbox(label="Enter a term or word to match and find LOINC, SNOMED and OMS clinical terminologies.") output1 = gr.DataFrame(label="LOINC Terminology") output2 = gr.DataFrame(label="LOINC Assessment Panels") output3 = gr.DataFrame(label="SNOMED Terminology") output4 = gr.DataFrame(label="SNOMED and OMS Terminology") #output1 = gr.TextArea(label="Output Match LOINC", max_lines=10, interactive=True, ) #output2 = gr.TextArea(label="Output Match LOINC Panels and Forms", max_lines=10, interactive=True,) #output3 = gr.TextArea(label="Output Match SNOMED", max_lines=10, interactive=True,) #output4 = gr.TextArea(label="Output Match SNOMED", max_lines=10, interactive=True,) button1 = gr.Button("Match LOINC Clinical Terminology") button1.click(fn=MatchLOINC, inputs=name, outputs=output1) button2 = gr.Button("Match LOINC Panels and Forms") button2.click(fn=MatchLOINCPanelsandForms, inputs=name, outputs=output2) button3 = gr.Button("Match SNOMED Clinical Terminology") button3.click(fn=MatchSNOMED, inputs=name, outputs=output3) button3 = gr.Button("Match SNOMED and OMS Clinical Terminology") button3.click(fn=MatchOMS, inputs=name, outputs=output4) demo.launch(debug=True)