Skip to main content

The python package that returns Response of Google Gemini through API.

Project description

Open Interview PyPI

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.

pip download Code style: black Downloads

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

Open In Colab

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

open-interview-1.0.13.tar.gz (21.6 kB view details)

Uploaded Source

Built Distribution

open_interview-1.0.13-py3-none-any.whl (27.4 kB view details)

Uploaded Python 3

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

Hashes for open-interview-1.0.13.tar.gz
Algorithm Hash digest
SHA256 d12756a1c505b1b78b88d8d3e95aad02903f496c4e0a083372cafea3e5ce5499
MD5 7f8f90b349465b0668caee07ef03e91f
BLAKE2b-256 d05cfc518ce074f224bc9035385678f83e223d88fd731db9dfa16b9c7ec17419

See more details on using hashes here.

File details

Details for the file open_interview-1.0.13-py3-none-any.whl.

File metadata

File hashes

Hashes for open_interview-1.0.13-py3-none-any.whl
Algorithm Hash digest
SHA256 f7f9c959a3171be940a53a65522ef27092f406eb5afbec1173fe22ca2e67c165
MD5 846908b8f8ce6a964f584194a51aa9f4
BLAKE2b-256 6be86d9c540b80735baa0524c1447c37c7c3f281a932c343e23dc57fefb20003

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page