piotrkan's picture
Update app.py
2ad9a1d verified
'''gradio app script'''
import os
import csv
import sys
csv.field_size_limit(sys.maxsize) #hack for large csv outputs
import json
import gradio as gr
from src import data, model
def pdf_ext_wrapper(input_pdf:str)->dict:
"""
Wrapper for extracting entities from pdfs for gradio
Args:
input_pdf - path to the pdf to be read
Outs:
json file with extracted entities
"""
output= data.extract_txt_from_pdf(input_pdf)
output = model.extract_entities_with_context('en_ner_bc5cdr_md', output)
return json.dumps(output)
def main():
os.system('pip install https://s3-us-west-2.amazonaws.com/ai2-s2-scispacy/releases/v0.5.4/en_ner_bc5cdr_md-0.5.4.tar.gz')
demo = gr.Interface(
fn=pdf_ext_wrapper,
inputs=["file"],
outputs=[gr.JSON(label='Json output')],
examples = [os.path.join('data',pdf) for pdf in os.listdir('data')],
title = 'SciPDF NER extractor',
description = 'Prototype of NER extractor from scientific papers in PDF format',
)
demo.launch(show_error=True )
if __name__=='__main__':
main()