An open API service indexing awesome lists of open source software.

https://github.com/Doriandarko/RepoToTextForLLMs

Automate the analysis of GitHub repositories for LLMs with RepoToTextForLLMs. Fetch READMEs, structure, and non-binary files efficiently. Outputs include analysis prompts to aid in comprehensive repo evaluation
https://github.com/Doriandarko/RepoToTextForLLMs

Last synced: 2 months ago
JSON representation

Automate the analysis of GitHub repositories for LLMs with RepoToTextForLLMs. Fetch READMEs, structure, and non-binary files efficiently. Outputs include analysis prompts to aid in comprehensive repo evaluation

Awesome Lists containing this project

README

        

# RepoToTextForLLMs
![hero](https://cdn.discordapp.com/attachments/1047006708813271100/1216931386032656445/im.jpeg?ex=66022eab&is=65efb9ab&hm=d472a26ec77b50ce5ee094578f888fa8b6c893bc523a5633f6987a850ae3b8d8&)

Automates the analysis of GitHub repositories specifically tailored for usage with large context LLMs. This Python script efficiently fetches README files, repository structure, and non-binary file contents. Additionally, it provides structured outputs complete with pre-formatted prompts to guide further analysis of the repository's content.

## Features

- **README Retrieval:** Automatically extracts the content of README.md to provide an initial insight into the repository.
- **Structured Repository Traversal:** Maps out the repository's structure through an iterative traversal method, ensuring thorough coverage without the limitations of recursion.
- **Selective Content Extraction:** Retrieves text contents from files, intelligently skipping over binary files to streamline the analysis process.

## Prerequisites

To use **RepoToTextForLLMs**, you'll need:

- Python installed on your system.
- The `github` Python package.
- A GitHub Personal Access Token configured as an environment variable (`GITHUB_TOKEN`).

## Getting Started

1. Ensure Python and the required package (`PyGithub`) are installed:

```bash
pip install PyGithub tqdm
```

2. Set your GitHub Personal Access Token as an environment variable:

```python
GITHUB_TOKEN = os.getenv('GITHUB_TOKEN', 'YOUR TOKEN HERE')
```

## How to Use

1. Place the script in your desired directory.
2. Execute the script in your terminal:

```bash
python repototxt.py
```

3. Enter the GitHub repository URL when prompted. The script will process the repository and output its findings, including the README, structure, and file contents (excluding binary files), accompanied by analysis prompts.

## Contributing

Contributions to **RepoToTextForLLMs** are welcomed. Whether it's through submitting pull requests, reporting issues, or suggesting improvements, your input helps make this tool better for everyone.

## License

This project is licensed under the MIT License.