GithubHelp home page GithubHelp logo

readme-ai's Introduction


README-AI

◦ Generate beautiful and informative README.md documents.

◦ Developed with OpenAI's GPT language model APIs.


Markdown OpenAI Python pytest Bash Anaconda

GitHub top language GitHub commit activity GitHub last commit GitHub license

📖 Table of Contents


📍 Overview

README-AI is a powerful, user-friendly command-line tool that generates extensive README markdown documents for your software and data projects. By providing a remote repository URL or directory path to your codebase, this tool will document your entire project, leveraging the capabilities of large language models and OpenAI's GPT APIs.

🎯 Motivation

Simplifies the process of writing and maintaining high-quality project documentation. My aim for this project is to provide all skill levels a tool that improves their technical workflow, in an efficient and user-friendly manner. Ultimately, the goal of README-AI is to improve the adoption and usability of open-source projects, enabling everyone to better understand and use open-source tools.

⚠️ Disclaimer

README-AI is currently under development and has an opinionated configuration and setup. While this tool provides an excellent starting point for documentation, its important to review all text generated by the OpenAI API to ensure it accurately represents your codebase. Ensure all content in your repository is free of sensitive information before executing.

Additionally, regularly monitor your API usage and costs by visiting the OpenAI API Usage.


👾 Demo

demo video


⚙️ Features

1.
👇

📑 Codebase Documentation

◦ Repository File Summaries

  • Code summaries are generated for each file via OpenAI's gpt-3.5-turbo engine.
  • The File column in the markdown table contains a link to the file on GitHub.
docs


👇

🎖 Badges

◦ Introduction, Badges, & Table of Contents

  • The OpenAI API is prompted to create a 1-sentence phrase describing your project.
  • Project dependencies and metadata are visualized using Shields.io badges.
  • Badges are sorted by hex code, displayed from light to dark hues.
docs


👇

🧚 Prompted Text Generation

◦ Features Table & Overview

  • Detailed prompts are embedded with repository metadata and passed to the OpenAI API.
    • Features table highlights various technical attributes of your codebase.
    • Overview section describes your project's use case and applications.
features overview


👇

📦 Dynamic User Setup Guides

◦ Installation, Usage, & Testing

  • Generates instructions for installing, using, and testing your codebase.
  • README-AI currently supports this feature for code written with:
    • Python, Rust, Go, C, Kotlin, Java, JavaScript, TypeScript.
getting_started


👇

👩‍💻Contributing Guidelines & more!

contribute


👇

💥 Example Files

Markdown example files generated by the README-AI app!

Example File Repository Language Bytes
1️⃣ readme-python.md readme-ai Python

19,839

2️⃣ readme-typescript.md chatgpt-app-react-typescript TypeScript, React

988

3️⃣ readme-javascript.md assistant-chat-gpt-javascript JavaScript, React

212

4️⃣ readme-kotlin.md file.io-android-client Kotlin, Java, Android

113,649

5️⃣ readme-rust-c.md rust-c-app C, Rust

72

6️⃣ readme-go.md go-docker-app Go

41

7️⃣ readme-java.md java-minimal-todo Java

17,725

8️⃣ readme-fastapi-redis.md async-ml-inference Python, FastAPI, Redis

355

9️⃣ readme-mlops.md mlops-course Python, Jupyter

8,524

🔟 readme-pyflink.md flink-flow PyFlink

32


👇

📜 Custom README templates coming soon!

Developing a feature that allows users to select from a variety of README formats and styles.

Custom templates will be tailored for use-cases such as data, ai & ml, research, minimal, and more!

🔝 Return


🚀 Getting Started

✔️ Dependencies

Before you begin, ensure that you have the following prerequisites installed:

  • Python 3.8 or higher
  • Conda package manager (recommended)
  • Access to the OpenAI API (see the setup guide below)

📂 Repository

Most user's will run README-AI using the command-line interface, specifying their repository on run-time. However, if you would like to use the default configuration, you will need to update the configuration file with your repository's remote URL (GitHub, GitLab) or local directory pat on your machine.

# Repository Configuration
[git]
repository = "Insert your repository URL or local path here!"

🔐 OpenAI API

To use the README-AI application, you will need to create an account with OpenAI to generate an API key. The steps below outline this setup process:

OpenAI API User Guide
  1. Go to the OpenAI website.
  2. Click the "Sign up for free" button.
  3. Fill out the registration form with your information and agree to the terms of service.
  4. Once logged in, click on the "API" tab.
  5. Follow the instructions to create a new API key.
  6. Copy the API key and keep it in a secure place.

⚠️ Note

  • To maximize your experience with README-AI, it is recommended to set up a payment method on OpenAI's website. By doing so, you gain access to more powerful language models like gpt-3.5-turbo. Without a payment method, your usage will be restricted to the base gpt-3 models. This limitation might lead to less precise README files or potential errors during the generation process.

  • When using a payment method, make sure you have sufficient credits to run the README-AI application. Additionally, remember to regularly monitor your API usage and costs by visiting the OpenAI API Usage Dashboard. Please note that this API is not free and you will be charged for each request made, which can accumulate rapidly.

  • The generation of the README.md file should typically complete in under 1 minute. If it takes longer than a few minutes, please terminate the process.


📦 Installation

  1. Clone the readme-ai repository to your local machine.
git clone https://github.com/AI-General/readme-ai
  1. Navigate to the readme-ai directory.
cd readme-ai
  1. Use one of the following methods to install the required dependencies:
# With Bash
bash setup/setup.sh
# With Conda
conda create -n readmeai python=3.9 -y && \
conda activate readmeai && \
poetry install
# With Poetry
poetry install
# With Docker
docker pull zeroxeli/readme-ai:v0.1.0

🎮 Using README-AI

Use the command-line to provide the OpenAI API key (if not already set) and specify an output path for your README file, along with the path to your local repository or remote code repository. You can also provide the output path in the configuration file

Command-Line Arguments:

  • -k or --api-key: Your OpenAI API key.
  • -o or --output: The output path for your README.md file.
  • -r or --repository: The URL or path to your code repository.
  • -t or --template: The README template format to use. (Coming soon!)
  • l or --language: The language of text written in the README file (Coming soon!)
python src/main.py --api-key "YOUR_API_KEY" --output readme-ai.md --repository https://github.com/AI-General/readme-ai

Alternatively, export your OpenAI API key as an environment variable and run the following command:

conda activate readmeai

export OPENAI_API_KEY="YOUR_API_KEY"

python src/main.py -o readme-ai.md -r https://github.com/AI-General/readme-ai
# With Poetry
poetry shell

export OPENAI_API_KEY="YOUR_API_KEY"

poetry run python src/main.py -o readme-ai.md -r https://github.com/AI-General/readme-ai
# Run with Docker
docker run -it \
-e OPENAI_API_KEY="YOUR_API_KEY" \
-v "$(pwd)":/app \
-w /app zeroxeli/readme-ai:v0.1.0 \
python src/main.py -o readme-ai.md -r https://github.com/AI-General/readme-ai

🧪 Running Tests

To run the unit-tests for README-AI, use the following command.

bash scripts/test.sh

🔝 Return


🛠 Future Development

  • Add additional language support for populating the installation, usage, and test README sections.
  • Design and implement a variety of README template formats for different use-cases.
  • Add support for writing the README in any language (i.e. CN, ES, FR, JA, KO, RU).
  • Create UI with Textual or another framework to improve user experience.

📒 Changelog

Changelog


🤝 Contributing

Contributing Guidelines


📄 License

MIT


👏 Acknowledgments

Badges

🔝 Return


readme-ai's People

Contributors

ai-general avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.