{"id":31766598,"url":"https://github.com/dann-oliv/query_results_exporter","last_synced_at":"2025-10-10T00:51:43.895Z","repository":{"id":288631531,"uuid":"961986875","full_name":"Dann-Oliv/query_results_exporter","owner":"Dann-Oliv","description":"Script para acessar o banco de dados desejado e extrair uma planilha de resultados de acordo com a query inserida.","archived":false,"fork":false,"pushed_at":"2025-10-04T16:47:47.000Z","size":43,"stargazers_count":0,"open_issues_count":1,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-10-04T18:30:30.717Z","etag":null,"topics":["extract-data","python","sql"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/Dann-Oliv.png","metadata":{"files":{"readme":"readme.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2025-04-07T13:30:05.000Z","updated_at":"2025-10-03T19:18:56.000Z","dependencies_parsed_at":"2025-04-19T05:27:17.244Z","dependency_job_id":"2ada992f-3305-41ab-9e63-a9b3179989c2","html_url":"https://github.com/Dann-Oliv/query_results_exporter","commit_stats":null,"previous_names":["dann-oliv/query-results-to-excel","danilo-olvr/db_query_exporter","dann-oliv/db_query_exporter","dann-oliv/query_results_exporter"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/Dann-Oliv/query_results_exporter","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Dann-Oliv%2Fquery_results_exporter","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Dann-Oliv%2Fquery_results_exporter/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Dann-Oliv%2Fquery_results_exporter/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Dann-Oliv%2Fquery_results_exporter/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/Dann-Oliv","download_url":"https://codeload.github.com/Dann-Oliv/query_results_exporter/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Dann-Oliv%2Fquery_results_exporter/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":279002335,"owners_count":26083356,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-10-09T02:00:07.460Z","response_time":59,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["extract-data","python","sql"],"created_at":"2025-10-10T00:51:42.910Z","updated_at":"2025-10-10T00:51:43.886Z","avatar_url":"https://github.com/Dann-Oliv.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Query Results To Excel\n\nEste projeto tem como objetivo acessar múltiplos bancos de dados (Dentro de uma instância PostgreSQL ou MySQL) com estruturas iguais, executar uma consulta SQL e exportar os resultados para arquivos Excel (.xlsx). É possível agrupar os resultados de todas as bases em um único arquivo ou gerar um arquivo para cada base.\n\n## Funcionalidades\n- Conexão dinâmica com diferentes bancos de dados usando SQLAlchemy.\n- Suporte a PostgreSQL e MySQL.\n- Exportação dos resultados para Excel.\n- Log salvo em arquivo.\n\n## Estrutura do Projeto\n```\n├── conn_profiles.yaml                # Arquivo de credenciais\n├── conn_profiles.example.yaml        # Exemplo de configuração de credenciais\n├── requirements.txt                  # Dependências do projeto\n├── main.py                           # Script principal\n├── sql/\n│   └── exemplo.sql                   # Exemplo de query SQL\n└── out/                              # (Gerado) Planilhas exportadas\n```\n\n## Como usar\n\n### 1. Instale as dependências\nWindows\n```\npython -m venv .venv\n.venv/Scripts/activate\npip install -r requirements.txt\n```\nUnix\n```bash\npython -m venv .venv\nsource .venv/bin/activate\npip install -r requirements.txt\n```\n### 2. Configure as credenciais\nCrie um arquivo `conn_profiles.yaml` baseado no exemplo `conn_profiles.example.yaml`:\n```yaml\ndatabases:\n  nome_conexao:\n    engine: \"postgres\"  # ou \"mysql\"\n    host: \"hosto\"\n    port: 5432\n    username: \"usuario\"\n    password: \"senha\"\n    database: \"nome_database\"\n```\n\n### 3. Crie sua query\nSalve sua consulta SQL na pasta `sql/` (ex: `minha_query.sql`).\n\n\n### 4. Edite a query da função get_all_databases()\nAltere a query para pegar os nomes das databases de acordo com as suas condições.\n\n#### Pega todos os nomes de databases em uma instância do postgres.\nEx: \"SELECT datname FROM pg_database\" \n\n### 4. Execute o script\n```bash\npython main.py\n```\n\nO script irá solicitar:\n- Nome da conexão (conforme definido no `conn_profiles.yaml`)\n- Nome do arquivo com a query (ex: `minha_query.sql`)\n- Se deseja agrupar os resultados em um único arquivo Excel\n\nOs arquivos gerados serão salvos na pasta `out/`.\n\n### 5. Logs\nToda execução gera um log  em `log.txt` e também exibe as mensagens no terminal.\n\n## Exemplo de uso\n```\nInforme o nome da conexão no YAML: localhost\nInforme o nome do arquivo com a query: minha_query.sql\nDeseja consolidar os resultados em um único arquivo? (y/n): y\n```\n\n---\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdann-oliv%2Fquery_results_exporter","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdann-oliv%2Fquery_results_exporter","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdann-oliv%2Fquery_results_exporter/lists"}