File size: 4,604 Bytes
318df0b
d708c06
318df0b
d708c06
 
d5e81f7
d708c06
 
828df56
318df0b
d5e81f7
d708c06
d5e81f7
d708c06
 
 
 
 
 
 
a7ddb9f
828df56
d5e81f7
712685a
 
d5e81f7
828df56
 
 
 
 
318df0b
 
 
d5e81f7
318df0b
 
712685a
 
 
 
 
 
 
 
 
 
 
 
 
 
 
318df0b
 
e1d2667
 
 
 
 
 
 
622b416
d708c06
e1d2667
 
318df0b
 
 
d5e81f7
 
 
84c8e82
d5e81f7
 
1ac1b15
318df0b
 
712685a
d5e81f7
 
 
 
 
 
712685a
d5e81f7
 
 
712685a
d5e81f7
 
 
712685a
d5e81f7
 
 
712685a
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
from dotenv import load_dotenv
# import io
import streamlit as st
# import streamlit.components.v1 as components
# import base64

# from langchain.prompts import PromptTemplate
# from langchain_core.output_parsers import PydanticOutputParser
from langchain_anthropic import ChatAnthropic
from langchain_openai import ChatOpenAI
from langchain_groq import ChatGroq
# from langchain_google_genai import ChatGoogleGenerativeAI
from langchain_google_genai import ChatGoogleGenerativeAI
# from langchain_core.exceptions import OutputParserException
# from pydantic import ValidationError
# from langchain_core.pydantic_v1 import BaseModel, Field
# from resume_template import Resume
# from json import JSONDecodeError
# import PyPDF2
# import json
import time
import os

import resume_helpers


# Set the LANGCHAIN_TRACING_V2 environment variable to 'true'
os.environ['LANGCHAIN_TRACING_V2'] = 'true'

# Set the LANGCHAIN_PROJECT environment variable to the desired project name
os.environ['LANGCHAIN_PROJECT'] = 'Resume_Project'

load_dotenv()

st.set_page_config(layout="wide")

st.title("Resume Parser")
col1, col2 = st.columns([1,6])

with col1:
    st.image("llamallms.png", use_column_width=True)

with col2:
    st.write("""
    ## πŸ“ Unlocking the Power of LLMs πŸ”“

    Welcome to the Resume Parser, a powerful tool designed to extract structured information from resumes using the magic of Language Models (LLMs)! πŸͺ„πŸ“„ As a data scientist and military veteran, I understand the importance of efficiency and accuracy when it comes to processing information. That's why I've created this app to showcase how different LLMs can help us parse resumes with ease. πŸ’ͺ

    Resumes come in all shapes and sizes, and standardization is often a distant dream. 😴 But with the right LLM by your side, you can extract key information like personal details, education, work experience, and more, all with just a few clicks! πŸ–±οΈ Plus, by comparing the performance of various models, you can find the perfect balance of speed, accuracy, and cost for your specific use case. πŸ’°

    So, whether you're a recruiter looking to streamline your hiring process, or a data enthusiast curious about the capabilities of LLMs, the Resume Parser has got you covered! πŸ™Œ Upload a resume, select your models, and watch the magic happen. 🎩✨ Let's unlock the full potential of LLMs together and make resume parsing a breeze! 😎
    """)

llm_dict = {
    "GPT-4o-mini": ChatOpenAI(temperature=0, model_name="gpt-4o-mini"),
    "GPT-4o": ChatOpenAI(temperature=0, model_name="gpt-4o"),
    "Anthropic 3.5 Haiku": ChatAnthropic(model="claude-3-5-haiku-latest"),
    "Anthropic 3.5 Sonnet": ChatAnthropic(model="claude-3-5-sonnet-latest"),
    "Llama 3.1 8b instant": ChatGroq(model_name="llama-3.1-8b-instant"),
    "Llama 3.3 70b": ChatGroq(model_name="llama-3.3-70b-versatile"),
    "Gemma 2 9b": ChatGroq(model_name="gemma2-9b-it"),
    "Mixtral 8x7b": ChatGroq(model_name="mixtral-8x7b-32768"),
    "Gemini 1.5 Pro": ChatGoogleGenerativeAI(model="gemini-1.5-pro"),
    "Gemini 2.0 Flash": ChatGoogleGenerativeAI(model="gemini-2.0-flash-exp"),
    "Gemini 1.5 Flash 8B": ChatGoogleGenerativeAI(model="gemini-1.5-flash-8b")
}

uploaded_file = st.file_uploader("Upload a PDF file", type="pdf")
col1, col2 = st.columns(2)

with col1:
    selected_model1 = st.selectbox("Select Model 1", list(llm_dict.keys()), index=list(llm_dict.keys()).index("Llama 3.3 70b"))

with col2:
    selected_model2 = st.selectbox("Select Model 2", list(llm_dict.keys()), index=list(llm_dict.keys()).index("Mixtral 8x7b"))

if uploaded_file is not None:
    text = resume_helpers.pdf_to_string(uploaded_file)

    if st.button("Extract Resume Fields"):
        col1, col2 = st.columns(2)

        with col1:
            start_time = time.time()
            extracted_fields1 = resume_helpers.extract_resume_fields(text, selected_model1)
            end_time = time.time()
            elapsed_time = end_time - start_time
            st.write(f"Extraction completed in {elapsed_time:.2f} seconds")
            resume_helpers.display_extracted_fields(extracted_fields1, f"{selected_model1} Extracted Fields ")

        with col2:
            start_time = time.time()
            extracted_fields2 = resume_helpers.extract_resume_fields(text, selected_model2)
            end_time = time.time()
            elapsed_time = end_time - start_time
            st.write(f"Extraction completed in {elapsed_time:.2f} seconds")
            resume_helpers.display_extracted_fields(extracted_fields2, f"{selected_model2} Extracted Fields ")