# set path import glob, os, sys; sys.path.append('../scripts') #import helper import scripts.process as pre import scripts.clean as clean #import needed libraries import seaborn as sns from pandas import DataFrame from keybert import KeyBERT from transformers import pipeline import matplotlib.pyplot as plt import numpy as np import streamlit as st import pandas as pd import matplotlib.pyplot as plt import tempfile import sqlite3 def app(): with st.container(): st.markdown("

Analyse Policy Document

", unsafe_allow_html=True) st.write(' ') st.write(' ') with st.expander("ℹī¸ - About this app", expanded=True): st.write( """ The *Analyse Policy Document* app is an easy-to-use interface built in Streamlit for analyzing policy documents - developed by GIZ Data and the Sustainable Development Solution Network. \n 1. Keyword heatmap \n 2. SDG Classification for the paragraphs/texts in the document """ ) st.markdown("") st.markdown("") st.markdown("## 📌 Step One: Upload document ") with st.container(): file = st.file_uploader('Upload PDF File', type=['pdf', 'docx', 'txt']) if file is not None: with tempfile.NamedTemporaryFile(mode="wb") as temp: bytes_data = file.getvalue() temp.write(bytes_data) st.write("Filename: ", file.name) # load document docs = pre.load_document(temp.name, file) # preprocess document docs_processed, df, all_text, par_list = clean.preprocessingForSDG(docs) # testing # st.write(len(all_text)) # for i in par_list: # st.write(i) @st.cache(allow_output_mutation=True) def load_keyBert(): return KeyBERT() kw_model = load_keyBert() keywords = kw_model.extract_keywords( all_text, keyphrase_ngram_range=(1, 3), use_mmr=True, stop_words="english", top_n=10, diversity=0.7, ) st.markdown("## 🎈 What is my document about?") df = ( DataFrame(keywords, columns=["Keyword/Keyphrase", "Relevancy"]) .sort_values(by="Relevancy", ascending=False) .reset_index(drop=True) ) # Create and generate a word cloud image: #plt.show() st.pyplot() df.index += 1 # Add styling cmGreen = sns.light_palette("green", as_cmap=True) cmRed = sns.light_palette("red", as_cmap=True) df = df.style.background_gradient( cmap=cmGreen, subset=[ "Relevancy", ], ) c1, c2, c3 = st.columns([1, 3, 1]) format_dictionary = { "Relevancy": "{:.1%}", } df = df.format(format_dictionary) with c2: st.table(df) ######## SDG classiciation # @st.cache(allow_output_mutation=True) # def load_sdgClassifier(): # classifier = pipeline("text-classification", model= "../models/osdg_sdg/") # return classifier # load from disc (github repo) for performance boost @st.cache(allow_output_mutation=True) def load_sdgClassifier(): classifier = pipeline("text-classification", model= "jonas/sdg_classifier_osdg") return classifier classifier = load_sdgClassifier() # # not needed, par list comes from pre_processing function already # word_list = all_text.split() # len_word_list = len(word_list) # par_list = [] # par_len = 130 # for i in range(0,len_word_list // par_len): # string_part = ' '.join(word_list[i*par_len:(i+1)*par_len]) # par_list.append(string_part) labels = classifier(par_list) labels_= [(l['label'],l['score']) for l in labels] df = DataFrame(labels_, columns=["SDG", "Relevancy"]) df['text'] = par_list df = df.sort_values(by="Relevancy", ascending=False).reset_index(drop=True) df.index += 1 df =df[df['Relevancy']>.85] x = df['SDG'].value_counts() plt.rcParams['font.size'] = 25 colors = plt.get_cmap('Blues')(np.linspace(0.2, 0.7, len(x))) # plot fig, ax = plt.subplots() ax.pie(x, colors=colors, radius=2, center=(4, 4), wedgeprops={"linewidth": 1, "edgecolor": "white"}, frame=False,labels =list(x.index)) st.markdown("## 🎈 Anything related to SDGs?") c4, c5, c6 = st.columns([5, 7, 1]) # Add styling cmGreen = sns.light_palette("green", as_cmap=True) cmRed = sns.light_palette("red", as_cmap=True) df = df.style.background_gradient( cmap=cmGreen, subset=[ "Relevancy", ], ) format_dictionary = { "Relevancy": "{:.1%}", } df = df.format(format_dictionary) with c4: st.pyplot(fig) with c5: st.table(df)