ChatGPTFileProcessor is a C# application that reads and processes documents (.txt, .pdf, and .docx) using OpenAI's ChatGPT to generate structured educational content. The application extracts definitions, multiple-choice questions (MCQs), flashcards, and vocabulary lists with Arabic translations, producing well-organized output files for each type. It’s ideal for educators, students, and content creators looking for a streamlined, AI-driven approach to content generation.
- Features
- Installation
- Creating Your OpenAI ChatGPT API Key
- Usage
- Output Files
- Troubleshooting
- Future Improvements
- Contributing
- License
- Multi-Format Support: Process text files, PDF documents, and Word files for diverse content sources.
- Structured Content Generation:
- Definitions: Clear explanations for key terms.
- MCQs: Multiple-choice questions with answer keys.
- Flashcards: Term-definition pairs for effective learning.
- Vocabulary: English terms translated to Arabic for bilingual content.
 
- OpenAI API Integration: Leverages ChatGPT models to provide precise and relevant content extraction.
- Customizable Options:
- Select different GPT models to tailor the level of detail and processing scope.
- Adjustable prompts and content structure for custom formatting and structure.
 
- User-Friendly Interface:
- Model selection and API key management.
- Real-time status updates and error handling.
 
- Organized Output Files: Each content type is saved to a unique, formatted file, ensuring easy access and readability.
Before installing ChatGPTFileProcessor, ensure you have the following prerequisites:
- .NET 5.0 or higher
- OpenAI API Key
- Microsoft Office (for Word document processing)
You can install ChatGPTFileProcessor using one of the following methods based on your preference:
Follow these steps to build and run the application from the source code.
- 
Clone the Repository: git clone https://github.com/MohammedTsmu/ChatGPTFileProcessor.git 
- 
Open the Project in Visual Studio: - Navigate to the cloned repository folder.
- Open the ChatGPTFileProcessor.slnsolution file with Visual Studio.
 
- 
Restore NuGet Packages: - If prompted, restore the required NuGet packages to ensure all dependencies are installed.
 
- 
Add Your OpenAI API Key: - Run the application.
- In the UI, navigate to the API Key section.
- Input your OpenAI API key to enable API access.
 
- 
Run the Application: - Start the application from Visual Studio.
- Ensure that the API key is correctly entered to proceed with document processing.
 
If you prefer not to build the application from source, you can download precompiled releases.
- 
Navigate to the Releases Page: - Go to the ChatGPTFileProcessor Releases page on GitHub.
 
- 
Download the Latest Release: - Find the latest stable release.
- Download the appropriate installer or executable for your operating system (e.g., .exefor Windows).
 
- 
Install the Application: - Windows:
- Run the downloaded .exefile.
- Follow the on-screen instructions to complete the installation.
 
- Run the downloaded 
- macOS/Linux:
- Depending on the release assets, follow the provided instructions or extract the downloaded archive.
- Ensure you have the necessary permissions to run the executable.
 
 
- Windows:
- 
Launch the Application: - After installation, open ChatGPTFileProcessor from your applications menu or installation directory.
 
- 
Configure Your API Key: - In the application's UI, navigate to the API Key section.
- Input your OpenAI API key to enable API access.
 
⚠️ Note: Always ensure you download releases from the official GitHub Releases page to avoid malicious software.
To use ChatGPTFileProcessor, you need an OpenAI API key. Follow the detailed steps below to create and obtain your own API key:
- 
Visit OpenAI's Website: Navigate to OpenAI's Sign Up Page. 
- 
Create an Account: - New Users: Click on "Sign Up" and provide the required information, including your email address and a secure password.
- Existing Users: Click on "Log In" and enter your credentials.
 
- 
Verify Your Email: After signing up, OpenAI will send a verification email to your registered email address. Click the verification link in the email to activate your account. 
- 
Log In to Your Account: Go to OpenAI's Platform and log in using your credentials. 
- 
Navigate to API Keys: - Once logged in, click on your profile icon located at the top-right corner.
- From the dropdown menu, select "API Keys".
 
- 
Generate a New Key: - Click on the "Create new secret key" button.
 
- 
Name Your Key: - Provide a recognizable name for your API key (e.g., ChatGPTFileProcessor Key).
 
- Provide a recognizable name for your API key (e.g., 
- 
Copy the API Key: - Once generated, copy the API key immediately. For security reasons, this is the only time the full key will be displayed.
 
- 
Store the Key Securely: - Save the API key in a secure location, such as a password manager, to prevent unauthorized access.
 
- 
Review Pricing Plans: - OpenAI offers various pricing tiers. Review them here to choose a plan that fits your usage needs.
 
- 
Add Payment Method: - If prompted, add a valid payment method to activate your API key for usage beyond the free tier.
 
- 
Open the Application: - Launch ChatGPTFileProcessor from Visual Studio or your installed applications.
 
- 
Navigate to API Key Section: - In the application's UI, find the API Key section.
 
- 
Input Your API Key: - Paste the copied API key into the designated field.
 
- 
Save and Confirm: - Save the changes and confirm that the application recognizes the API key. You should now be able to use the application's full functionality.
 
- 
OpenAI API Documentation: For more detailed information, visit the OpenAI API Docs. 
- 
Managing Your API Keys: Learn how to manage, regenerate, or revoke your API keys here. 
⚠️ Important Security Notice:
- Do Not Share Your API Key: Treat your API key like a password. Do not share it publicly or commit it to version control systems.
- Regenerate if Compromised: If you suspect your API key has been exposed, regenerate it immediately from the OpenAI dashboard.
- 
Select Model: - Choose from the available ChatGPT models to determine the desired processing depth and content generation style.
 
- 
Choose File: - Upload a .txt,.pdf, or.docxdocument that you want to process.
 
- Upload a 
- 
Start Processing: - Click the Process File button to begin extracting definitions, MCQs, flashcards, and vocabulary from the uploaded document.
 
- 
Access Outputs: - Once processing is complete, the generated files are saved to your Desktop.
- Each file is uniquely named based on the content type and the model used for processing.
 
Each content type is saved as a separate file in the following structure:
- Definitions_Output: Provides terms with their definitions.
- MCQs_Output: Contains multiple-choice questions with answer keys.
- Flashcards_Output: Flashcards formatted with term-definition pairs.
- Vocabulary_Output: English terms with their Arabic translations.
| Term | Arabic Translation | 
|---|---|
| Solubility | الذوبانية | 
| Antiseptics | مطهرات | 
| Absorption | الامتصاص | 
- 
Errors in Output Format: - If the output format is incorrect, adjust the prompts in the code to refine the structure as needed.
 
- 
Index Errors: - Ensure that the file you are trying to process is in a supported format (.txt,.pdf,.docx).
- Retry processing after confirming the file format.
 
- Ensure that the file you are trying to process is in a supported format (
- 
Custom Output Location: - Allow users to specify custom save locations for the generated files.
 
- 
Additional Language Support: - Integrate more translation options to support additional languages beyond Arabic.
 
- 
Batch Processing: - Enable the processing of multiple files simultaneously to enhance workflow efficiency.
 
Contributions are welcome! Please follow these steps to contribute:
- 
Fork the Repository. 
- 
Create a New Branch for your feature or bugfix. 
- 
Commit Your Changes with clear and descriptive messages. 
- 
Submit a Pull Request detailing the changes and the purpose behind them. 
- 
when run visual studio community first time, it will not open the project you should do > one build first. 
- 
the app will not work specially when upload file, because it is designed to lunch on 64bit so do it via [build > configuration manager > set the platform to x64]  
 Figure: Build configuration location or via build in above menu 
 Figure: Build configuration location or via build in above menu 
 Figure: Build configuration location or via build in above menu
This project is licensed under the AGPL-3.0 License.



