bainskarman commited on
Commit
7e4deac
β€’
1 Parent(s): fbfa256

Upload 7 files

Browse files
Files changed (7) hide show
  1. ATS_score.py +17 -0
  2. README.md +4 -5
  3. app.py +75 -0
  4. convert.py +27 -0
  5. job_description.txt +39 -0
  6. model.py +22 -0
  7. requirements.txt +5 -0
ATS_score.py ADDED
@@ -0,0 +1,17 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ #find ats score
2
+ from sklearn.feature_extraction.text import TfidfVectorizer
3
+ from sklearn.metrics.pairwise import cosine_similarity
4
+ from sklearn.feature_extraction import _stop_words
5
+ from convert import ExtractPDFText
6
+
7
+ def calculateATSscore(resume_data, job_description):
8
+ stopwords = list(_stop_words.ENGLISH_STOP_WORDS)
9
+ vectorizer = TfidfVectorizer(stop_words=stopwords)
10
+ vectors = vectorizer.fit_transform([job_description, resume_data])
11
+ similarity_value = cosine_similarity(vectors)
12
+ print(similarity_value)
13
+ # return similarity_value[0,1]
14
+ return similarity_value[0,1]
15
+
16
+
17
+
README.md CHANGED
@@ -1,13 +1,12 @@
1
  ---
2
- title: ATSScanner
3
- emoji: 🐠
4
- colorFrom: pink
5
  colorTo: yellow
6
  sdk: streamlit
7
- sdk_version: 1.39.0
8
  app_file: app.py
9
  pinned: false
10
- short_description: Check if your resume will go through ATS
11
  ---
12
 
13
  Check out the configuration reference at https://huggingface.co/docs/hub/spaces-config-reference
 
1
  ---
2
+ title: AI Powered Resume ATS Screening
3
+ emoji: πŸƒ
4
+ colorFrom: gray
5
  colorTo: yellow
6
  sdk: streamlit
7
+ sdk_version: 1.29.0
8
  app_file: app.py
9
  pinned: false
 
10
  ---
11
 
12
  Check out the configuration reference at https://huggingface.co/docs/hub/spaces-config-reference
app.py ADDED
@@ -0,0 +1,75 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ # Import necessary libraries
2
+ from convert import ExtractPDFText
3
+ from ATS_score import calculateATSscore
4
+ from model import modelFeedback
5
+ import streamlit as st
6
+ import time
7
+
8
+
9
+ if "page_number" not in st.session_state:
10
+ st.session_state.page_number = 1
11
+
12
+ if "resume_data" not in st.session_state:
13
+ st.session_state.resume_data = ""
14
+
15
+ if "jobdescription" not in st.session_state:
16
+ st.session_state.jobdescription = ""
17
+
18
+ def set_page_number_and_reset_data():
19
+ st.session_state.page_number = 1
20
+ st.session_state.resume_data = ""
21
+
22
+
23
+ def page1():
24
+ st.title("AI-Powered ATS Screening")
25
+ if not st.session_state.resume_data:
26
+ pdf = st.file_uploader(label="Upload your resume", type="pdf")
27
+ st.write("No Resume Yet? Create one [here](https://www.overleaf.com/latex/templates/tagged/cv)")
28
+
29
+ if pdf:
30
+ st.success("Resume uploaded successfully.")
31
+ st.session_state.resume_data = ExtractPDFText(pdf)
32
+
33
+ def page2():
34
+ st.title("AI-Powered ATS Screening: Job Description")
35
+ st.session_state.jobdescription = st.text_area("Job Description: ")
36
+ st.info("You can just copy paste from the job portal")
37
+ submit = st.button("Submit")
38
+
39
+ if submit:
40
+ start()
41
+
42
+ def page3():
43
+ st.title("Your Resume data: ")
44
+ if st.session_state.resume_data:
45
+ st.write(st.session_state.resume_data)
46
+ else:
47
+ st.error("Please upload your resume to view the extracted data")
48
+
49
+ def start():
50
+ if st.session_state.resume_data and st.session_state.jobdescription:
51
+ with st.spinner("Hold on, we're calculating your ATS Score..."):
52
+ ATS_score = calculateATSscore(st.session_state.resume_data, st.session_state.jobdescription)
53
+ model_feedback = modelFeedback(ATS_score, st.session_state.resume_data)
54
+ # time.sleep(5)
55
+
56
+
57
+ st.subheader("AI FEEDBACK:")
58
+ st.write(model_feedback.text)
59
+
60
+ else:
61
+ st.info("Please, upload Resume and Provide the Job Description")
62
+
63
+ if st.session_state.page_number == 1:
64
+ page1()
65
+ elif st.session_state.page_number == 2:
66
+ page2()
67
+ elif st.session_state.page_number == 3:
68
+ page3()
69
+
70
+ if st.session_state.page_number == 1:
71
+ st.button("View your Extracted Resume data", on_click = lambda: setattr(st.session_state,"page_number", 3))
72
+ st.button("Go to Job Description Page", on_click=lambda: setattr(st.session_state, "page_number", 2))
73
+ else:
74
+ st.button("Go to PDF Upload Page", on_click=lambda: set_page_number_and_reset_data())
75
+
convert.py ADDED
@@ -0,0 +1,27 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import fitz
2
+ from io import BytesIO
3
+ import streamlit as st
4
+
5
+ def ExtractPDFText(pdf):
6
+ content = ""
7
+ pdf_bytes = pdf.read()
8
+
9
+ try:
10
+ pdf_document = fitz.open("dummy.pdf", pdf_bytes)
11
+
12
+ # Iterate through pages and extract text
13
+ for page_number in range(pdf_document.page_count):
14
+ page = pdf_document[page_number]
15
+ text = page.get_text()
16
+ content += text
17
+
18
+ except Exception as e:
19
+ st.error(f"Error extracting text from PDF: {e}")
20
+
21
+ finally:
22
+ if "pdf_document" in locals():
23
+ pdf_document.close()
24
+
25
+ return content
26
+
27
+
job_description.txt ADDED
@@ -0,0 +1,39 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ Job Title: Data Scientist
2
+ Company: XYZ Corporation
3
+ Location: Mountain View, CA (for illustrative purposes only)
4
+
5
+ Job Overview:
6
+
7
+ XYZ Corporation is seeking a highly skilled and motivated Data Scientist to join our dynamic team. As a Data Scientist, you will play a key role in extracting valuable insights from our vast datasets to drive informed decision-making and contribute to the company's success. This role involves leveraging advanced analytics and machine learning techniques to solve complex business problems.
8
+
9
+ Responsibilities:
10
+
11
+ Develop and implement machine learning models for predictive and prescriptive analytics.
12
+ Analyze large datasets to identify trends, patterns, and correlations that can inform business strategies.
13
+ Collaborate with cross-functional teams to understand business requirements and provide data-driven solutions.
14
+ Design and implement experiments to validate hypotheses and improve model performance.
15
+ Stay abreast of the latest developments in data science, machine learning, and industry best practices.
16
+ Present findings and insights to both technical and non-technical stakeholders in a clear and concise manner.
17
+ Ensure the quality, reliability, and integrity of data used for analysis.
18
+ Qualifications:
19
+
20
+ Master's or Ph.D. in a quantitative field such as Computer Science, Statistics, or related discipline.
21
+ Proven experience as a Data Scientist with a strong track record of successfully applying machine learning techniques to real-world problems.
22
+ Proficiency in programming languages such as Python or R.
23
+ Solid understanding of statistical concepts and techniques.
24
+ Strong analytical and problem-solving skills.
25
+ Excellent communication and collaboration skills.
26
+ Preferred Skills:
27
+
28
+ Experience with big data technologies such as Hadoop, Spark, or similar.
29
+ Knowledge of cloud computing platforms (e.g., Google Cloud, AWS, Azure).
30
+ Familiarity with deep learning frameworks (e.g., TensorFlow, PyTorch).
31
+ Previous experience in the tech industry.
32
+ Benefits:
33
+
34
+ Competitive salary and performance-based bonuses.
35
+ Comprehensive health, dental, and vision insurance.
36
+ 401(k) retirement plan.
37
+ Professional development opportunities.
38
+ Flexible work hours and remote work options.
39
+ This is just a generic example, and actual job descriptions may vary. It's important to carefully read and understand the specific requirements and expectations outlined in the job postings of the companies you are interested in.
model.py ADDED
@@ -0,0 +1,22 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import google.generativeai as genai
2
+ import os
3
+ from dotenv import load_dotenv
4
+ from convert import ExtractPDFText
5
+ load_dotenv()
6
+
7
+ genai.configure(api_key = os.environ["GOOGLE_API_KEY"])
8
+
9
+ model = genai.GenerativeModel("gemini-pro")
10
+
11
+ def modelFeedback(ats_score,resume_data):
12
+
13
+ input_prompt = f"""
14
+ You are now an ATS Score analyzer and given ATS Score is {int(ats_score*100)}%.
15
+ Your task is to provide feedback to the user based on the ATS score.
16
+ print ATS score first. mention where resume is good and where resume lacks.
17
+ talk about each section of user's resume and talk good and bad points of it.
18
+ """
19
+ response = model.generate_content([input_prompt,resume_data],stream=True)
20
+ response.resolve()
21
+
22
+ return response
requirements.txt ADDED
@@ -0,0 +1,5 @@
 
 
 
 
 
 
1
+ pymupdf
2
+ scikit-learn
3
+ google.generativeai
4
+ streamlit
5
+ python-dotenv