import subprocess import pkg_resources import sys import time def update_gradio(): """Atualiza o Gradio para a versão mais recente.""" try: subprocess.check_call([sys.executable, '-m', 'pip', 'install', '--upgrade', 'gradio']) print("Gradio atualizado com sucesso!") print("Reiniciando aplicação...") time.sleep(2) python = sys.executable subprocess.Popen([python] + sys.argv) sys.exit(0) except Exception as e: print(f"Erro ao atualizar Gradio: {e}") # Verifica e atualiza o Gradio se necessário try: current_version = pkg_resources.get_distribution('gradio').version latest_version = subprocess.check_output([sys.executable, '-m', 'pip', 'index', 'versions', 'gradio']).decode().split('\n')[0].split(' ')[-1] if current_version != latest_version: print(f"Atualizando Gradio: {current_version} -> {latest_version}") update_gradio() else: print(f"Gradio já está na versão mais recente: {current_version}") except: print("Instalando Gradio...") update_gradio() # Importações necessárias import gradio as gr import rdflib import requests import matplotlib.pyplot as plt import networkx as nx from io import BytesIO import base64 def load_names_from_url(jsonld_url): """Carrega e extrai os nomes do arquivo JSON-LD a partir de uma URL.""" try: response = requests.get(jsonld_url) data = response.json() names = [] for item in data: if 'name' in item: names.append(item['name']) return sorted(names) # Retorna nomes ordenados alfabeticamente except Exception as e: print(f"Erro ao carregar dados: {e}") return [] def build_graph_from_jsonld(jsonld_url, selected_name): """Constrói o grafo a partir dos dados JSON-LD.""" try: response = requests.get(jsonld_url) data = response.json() selected_data = next((item for item in data if item['name'] == selected_name), None) if not selected_data: return "Local não encontrado." G = nx.DiGraph() # Adicionar nó do Place place_id = selected_data['@id'] place_label = f"schema:Place\nName: {selected_data['name']}\nDescription: {selected_data['description'][:30]}..." G.add_node(place_id, label=place_label) # Adicionar nó de GeoCoordinates geo_data = selected_data['geo'] geo_id = geo_data['@id'] geo_label = f"geo:SpatialThing\nLat: {geo_data['lat']}\nLong: {geo_data['long']}\nFeatureCode: {geo_data['gn:featureCode']}\nFeatureCodeName: {geo_data['gn:featureCodeName']}\nName: {geo_data['gn:name']}" G.add_node(geo_id, label=geo_label) G.add_edge(place_id, geo_id, label="schema:geo") # Adicionar nós de CreativeWork for work in selected_data.get('subjectOf', []): work_id = work['@id'] work_label = f"schema:CreativeWork\nHeadline: {work['headline']}\nGenre: {work['genre']}\nDatePublished: {work['datePublished']}\nText: {work['text'][:30]}...\nLanguage: {work['inLanguage']}" G.add_node(work_id, label=work_label) G.add_edge(place_id, work_id, label="schema:subjectOf") return G except Exception as e: return f"Erro ao construir grafo: {e}" def run_query_and_visualize(selected_location, jsonld_url): """Executa a consulta e visualiza o resultado.""" try: if not selected_location: return '
Selecione um local para visualizar o grafo
' G = build_graph_from_jsonld(jsonld_url, selected_location) if isinstance(G, str): # Caso de erro return f'
{G}
' plt.figure(figsize=(15, 10)) pos = nx.spring_layout(G) nx.draw_networkx_nodes(G, pos, node_size=3000, node_color="skyblue", alpha=0.9) nx.draw_networkx_edges(G, pos, width=2, alpha=0.5, edge_color='gray') nx.draw_networkx_labels(G, pos, labels=nx.get_node_attributes(G, 'label'), font_size=9, font_color="black") nx.draw_networkx_edge_labels(G, pos, edge_labels=nx.get_edge_attributes(G, 'label'), font_size=9, font_color="red") plt.title(f"Grafo para: {selected_location}", size=15) plt.axis('off') buf = BytesIO() plt.savefig(buf, format='png', dpi=300, bbox_inches='tight') buf.seek(0) img_str = base64.b64encode(buf.read()).decode() plt.close() return f'' except Exception as e: return f'
Erro ao gerar visualização: {e}
' # URL do arquivo JSON-LD jsonld_url = 'https://huggingface.co/spaces/histlearn/ShowGraph/raw/main/datafile.jsonld' # Carrega os nomes iniciais names = load_names_from_url(jsonld_url) # Interface Gradio with gr.Blocks() as demo: gr.Markdown(""" # Visualização de Grafos de Localidades Selecione um local para visualizar seu grafo de relacionamentos. """) with gr.Column(): selected_location = gr.Dropdown( choices=names, label="Selecione o Local", info="Escolha um local para ver suas relações" ) run_button = gr.Button("Visualizar Grafo", variant="primary") graph_output = gr.HTML( value='
Selecione um local e clique em "Visualizar Grafo"
' ) def on_run_button_click(selected_location): return run_query_and_visualize(selected_location, jsonld_url) run_button.click( fn=on_run_button_click, inputs=[selected_location], outputs=graph_output ) if __name__ == "__main__": demo.launch()