From b18f067cf570c3d2b300345a0af46362123f318c Mon Sep 17 00:00:00 2001 From: Ovler Date: Wed, 20 Nov 2024 03:38:44 -0500 Subject: [PATCH] chore: move code to cache the calculated pd for speedup --- src/ia_collection_analyzer/streamlit.py | 34 ++++++++++++------------- 1 file changed, 17 insertions(+), 17 deletions(-) diff --git a/src/ia_collection_analyzer/streamlit.py b/src/ia_collection_analyzer/streamlit.py index 48c3fdd8..6af6709d 100644 --- a/src/ia_collection_analyzer/streamlit.py +++ b/src/ia_collection_analyzer/streamlit.py @@ -42,6 +42,23 @@ ) items = fetch_metadata(collection_id) items_pd = pd.DataFrame(items) + + data_transform_text = st.text("cleaning data...") + # drop columns with 80%+ nan + items_pd = items_pd.dropna(axis=1, thresh=0.8 * len(items_pd)) + items_pd = items_pd.dropna(axis=0, thresh=0.7 * len(items_pd.columns)) + # drop mediatype=collections + items_pd = items_pd[items_pd["mediatype"] != "collection"] + + # drop columns with different types inner. + # for col in items_pd.columns: + # items_pd[col] = items_pd[col].apply(lambda x: x if isinstance(x, type(items_pd[col][0])) else np.nan) + + # calculate metadata + data_transform_text.text("calculating metadata...") + items_pd["addeddate"] = pd.to_datetime(items_pd["addeddate"]) + items_pd["publicdate"] = pd.to_datetime(items_pd["publicdate"]) + data_transform_text.text("Data transformation and cleaning complete!") # Update cache st.session_state.collection_id = collection_id @@ -54,23 +71,6 @@ ) items_pd = st.session_state.items_pd -data_transform_text = st.text("cleaning data...") -# drop columns with 80%+ nan -items_pd = items_pd.dropna(axis=1, thresh=0.8 * len(items_pd)) -items_pd = items_pd.dropna(axis=0, thresh=0.7 * len(items_pd.columns)) -# drop mediatype=collections -items_pd = items_pd[items_pd["mediatype"] != "collection"] - -# drop columns with different types inner. -# for col in items_pd.columns: -# items_pd[col] = items_pd[col].apply(lambda x: x if isinstance(x, type(items_pd[col][0])) else np.nan) - -# calculate metadata -data_transform_text.text("calculating metadata...") -items_pd["addeddate"] = pd.to_datetime(items_pd["addeddate"]) -items_pd["publicdate"] = pd.to_datetime(items_pd["publicdate"]) -data_transform_text.text("Data transformation and cleaning complete!") - st.write("The collection contains the following items:") try: st.write(items_pd.head(10))