The python package that returns Response of Google Gemini through API.
Project description
Open Interview
Looking to practice mock interviews tailored to your resume and job description? Seeking an technical interview simulation?
Dive in with the Python open-source package open-interview
.
https://github.com/dsdanielpark/open-interview/assets/81407603/22f9b991-33e8-40d2-a4f2-b80199415767
Transform your job interview preparation into an unparalleled journey with Open Interview, where the avant-garde artificial intelligence of OpenAI, Anthropic, and Google is meticulously tailored to forge your path to success. Here, every interaction is designed to sculpt your technical and personal narrative into perfection, mirroring the exigencies of your dream job.
Stellar Features ✨
- 🌍 Universal Language Support: Emphasize the ability to accommodate all languages across the following features:
- 🖋️ Dynamic Q&A Alchemy: Craft your arsenal with precision—generate nuanced technical interview Q&As distilled from the essence of your resume and the job description.
- 📖 Document Genesis: Automate the creation of elegant Word documents (.docx), encapsulating your personalized interview Q&As for study and reflection.
- 🎧 Sonic Refinement: Convert your Q&As into audio files, enabling auditory mastery and convenience for your preparatory rituals.
- 🌐 Cosmos Customization: Navigate your preparation through customizable orbits—fine-tune preferences for job designation, interview cadence, lingua franca, and narrative complexity.
Commencing Voyage
Welcome to the nexus of your interview preparation odyssey.
[!IMPORTANT] Token usage for experimental projects can be high, possibly exhausting paid API tokens quickly. A long-response prompt is now active. Please see the document below to adjust system and user prompts accordingly.
Prerequisites
- Python >= 3.7: Ensure your command module is updated to version 3.7 or beyond.
- 🔑 API Keys - OpenAI, Anthropic, Google: Secure your access to the galaxies of OpenAI, Anthropic, and Google, embarking with the keys to unlock the full spectrum of your potential.
Installation 📦
pip install open-interview
git clone https://github.com/dsdanielpark/open-interview.git
pip install -r requirements.txt
Quick Start
Generate interview content using Claude or GPT models with minimal setup:
Using Claude
[!IMPORTANT] Increasing the
iteration
argument can generate more QAs but may lead to duplicates and excessive token usage, as it's an experimental feature.
from openinterview import InterviewManager
claudeToken = "<your_claude_token>"
claude_interview_manager = InterviewManager(api_key=claudeToken, engine="Claude")
jd = """
The 'jd', 'resume', and other arguments
can accommodate extensive text.
"""
claude_interview_manager.generate_interview(
jd=jd,
resume="path/resume.pdf or path/resume.txt or long text.",
position= "AI Researcher",
interview_type="techQAsFromResume",
language="English", # Any language you want
max_sentence=5,
output_dir="save/dirs",
iteration=1, # [Caution] You can make more QAs, But it cost token very fastly.
)
Using GPT
import openai
from openinterview import InterviewManager
openai.api_key = "<your_openai_token>"
gpt_interview_manager = InterviewManager(api_key=openai.api_key, engine="GPT")
gpt_interview_manager.generate_interview(
jd="This role demands a deep enthusiasm for AI development.", # Feasible for long text
resume="path/resume.pdf or path/resume.txt or long text.",
position= "AI Researcher",
interview_type="techQAsFromResume",
language="English", # Any language you want
max_sentence=5,
output_dir="save/dirs",
iteration=1, # [Caution] You can make more QAs, But it cost token very fastly.
)
The interview_type
arguments as follow:
- generalQAs: Ask about technical and personal skills in-depth.
- generalTechQAs: Ask basic professional questions related to the job.
- techQAsFromResume: Focus on technical skills listed on the resume.
- techQAsFromExperts: Questions based on interviewer's expertise.
- techQAs: Questions based on both parties' experiences.
- personalityQAs: Inquire about personal qualities.
- reviewResume: Identify and suggest improvements for the resume.
Playing Random Question Audio
To randomly play question.mp3
files from a specified folder, create an instance of the RandomPlayer
class with the folder path, and then invoke play_random_mp3
:
from openinterview import RandomPlayer
p = RandomPlayer(directory="path/to/output", interval=120) # Directory containing question.mp3 files
p.play_random_mp3()
Default plays randomly for 2 minutes. Press 'n' for next question, 'q' to quit.
Usage
For detailed examples, refer to the 📋Usage document for example code and prompting engineering or the 💻tutorial script.
- OpenAI GPT: Use
GptGenerator
for GPT-based content generation. - Anthropic Claude: Use
ClaudeGenerator
for Claude-based interviews.
You can use LangChain, LangSmith, LangServe, and LangGraph for faster and more efficient coding and services. You can check few-shot prompt template in LangChain. Also, you can try faster RAG with Llama Index. However, this project is used for general and efficient search for other my private projects.
Contribution
For detailed guidance on contributions, please refer to the contribution guide. We appreciate your interest in contributing and look forward to your valuable input.
Thank you for supporting our project.
FAQ & Support
For questions and support, visit our FAQ and Issues pages. Contributors are welcome! Submit issues, feature suggestions, or pull requests. Reach out to the core maintainer, Daniel Park, for direct contributions or queries.
License ©️
Apache 2.0 license, 2024.
The initial version of this project took roughly two days for a single person, including documentation for all processes.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file open-interview-1.0.13.tar.gz
.
File metadata
- Download URL: open-interview-1.0.13.tar.gz
- Upload date:
- Size: 21.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d12756a1c505b1b78b88d8d3e95aad02903f496c4e0a083372cafea3e5ce5499 |
|
MD5 | 7f8f90b349465b0668caee07ef03e91f |
|
BLAKE2b-256 | d05cfc518ce074f224bc9035385678f83e223d88fd731db9dfa16b9c7ec17419 |
File details
Details for the file open_interview-1.0.13-py3-none-any.whl
.
File metadata
- Download URL: open_interview-1.0.13-py3-none-any.whl
- Upload date:
- Size: 27.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f7f9c959a3171be940a53a65522ef27092f406eb5afbec1173fe22ca2e67c165 |
|
MD5 | 846908b8f8ce6a964f584194a51aa9f4 |
|
BLAKE2b-256 | 6be86d9c540b80735baa0524c1447c37c7c3f281a932c343e23dc57fefb20003 |