import logging import os from supabase import create_client, Client from fuzzywuzzy import fuzz from config import SUPABASE_URL, SUPABASE_KEY import json import logging url: str = SUPABASE_URL key: str = SUPABASE_KEY supabase: Client = create_client(url, key) def insert_papers_data(data,author_name ,table_name: str = 'papers'): if data == []: print("No data to insert") return formatted_data = [] for entry in data: entry = json.loads(entry) data_db = { 'doi_no': entry.get('doi'), 'title': entry.get('title'), 'summary': entry.get('summary'), 'authors': ", ".join(entry.get('authors',[])), 'year': entry.get('year'), 'pdf_link': entry.get('pdf_link'), 'references': ", ".join(entry.get('references')), 'categories': ", ".join(entry.get('categories')), 'comment': entry.get('comment'), 'journal_ref': entry.get('journal_ref'), 'source': entry.get('source'), 'primary_category': entry.get('primary_category'), 'published': entry.get('published'), 'author_name' : author_name, } formatted_data.append(data_db) data, count = supabase.table(table_name).insert(formatted_data).execute() def get_correct_author_name(user_input_author): authors_name_data = supabase.table('papers').select('author_name').execute() unique_authors = set(author_dict['author_name'] for author_dict in authors_name_data.data) unique_authors_list = list(unique_authors) similar_authors = [author for author in unique_authors_list if fuzz.ratio(user_input_author, author) > 60] if similar_authors: return similar_authors[0] else: print(f"No similar author found for '{user_input_author}'") return None def fetch_papers_data(author_name, fields_to_query = ["doi_no"],table_name: str = 'papers', all=False): author_name = get_correct_author_name(author_name) if all: data, count = supabase.table(table_name).select("*").eq('author_name', author_name).execute() return data data, count = supabase.table(table_name).select(",".join(fields_to_query)).eq('author_name', author_name).execute() return data[1]