Resume_matcher / app.py
Walid-Ahmed's picture
Create app.py
04f4231 verified
import gradio as gr
from sentence_transformers import SentenceTransformer, util
model = SentenceTransformer('paraphrase-MiniLM-L6-v2')
def match_resume(resume, job1, job2, job3):
# Calculate similarity
resume_embedding = model.encode(resume, convert_to_tensor=True)
# Encode each job description using a loop
job_embeddings = []
for job in [job1, job2, job3]:
job_embeddings.append(model.encode(job, convert_to_tensor=True))
# Calculate the similarities using a loop
similarities = []
for job_emb in job_embeddings:
similarity = util.pytorch_cos_sim(resume_embedding, job_emb).item() * 100
similarities.append(similarity)
best_job_index = 1
best_match = similarities[0]
for i in range(1, len(similarities)):
if similarities[i] > best_match:
best_match = similarities[i]
best_job_index = i + 1
results = []
for i, sim in enumerate(similarities):
results.append(f"Job {i+1}: {sim:.2f}% match")
results.append(f"Best Match: Job {best_job_index} with {best_match:.2f}%")
return "\n".join(results)
# Gradio interface
interface = gr.Interface(fn=match_resume,
inputs=["text", "text", "text", "text"],
outputs="text",
examples=[
["Experienced software developer skilled in Python and AI.",
"Looking for a Python developer with experience in AI and ML.",
"Seeking a data scientist with expertise in deep learning.",
"Hiring a web developer proficient in JavaScript and React."],
["Marketing specialist with a focus on digital campaigns.",
"Seeking a social media expert to manage brand presence.",
"Hiring a digital marketer with experience in SEO and PPC.",
"Looking for a content writer to create engaging blog posts."]
]
)
interface.launch()