This is an web scraping bot that automates the process of job applications on LinkedIn. It searches for jobs relevant to you, answers all questions in application form, customizes your resume based on the collected job information, such as skills required, description, about company, etc. and applies to the job. Can apply 100+ jobs in less than 1 hour.
Click on above image to watch the demo or use this link https://youtu.be/gMbB1fWZDHw
- Introduction
- Demo Video
- Index
- Install
- Configure
- Contributor Guidelines
- Features
- My letter for YOU ❤️
- Updates
- Disclaimer
- Terms and Conditions
- License
- Socials
- Support and Discussions
- Python 3.10 or above. Visit https://www.python.org/downloads/ to download and install Python, or for windows you could visit Microsoft Store and search for "Python". Please make sure Python is added to Path in System Environment Variables.
- Install necessary Undetected Chromedriver, PyAutoGUI and Setuptools packages. After Python is installed, OPEN a console/terminal or shell, Use below command that uses the pip command-line tool to install these 3 package.
pip install undetected-chromedriver pyautogui setuptools openai
- Download and install latest version of Google Chrome in it's default location, visit https://www.google.com/chrome to download it's installer.
- Clone the current git repo or download it as a zip file, url to the latest update https://github.com/GodsScion/Auto_job_applier_linkedIn.
- (Not needed if you set
stealth_mode = True
inconfig/settings.py
) Download and install the appropriate Chrome Driver for Google Chrome and paste it in the location Chrome was installed, visit https://googlechromelabs.github.io/chrome-for-testing/ to download.
OR
If you are using Windows, click onwindows-setup.bat
available in the/setup
folder, this will install the latest chromedriver automatically. - If you have questions or need help setting it up or to talk in general, join the github server: https://discord.gg/fFp7uUzWCY
- Open
personals.py
file in/config
folder and enter your details like name, phone number, address, etc. Whatever you want to fill in your applications. - Open
questions.py
file in/config
folder and enter your answers for application questions, configure wether you want the bot to pause before submission or pause if it can't answer unknown questions. - Open
search.py
file in/config
folder and enter your search preferences, job filters, configure the bot as per your needs (these settings decide which jobs to apply for or skip). - Open
secrets.py
file in/config
folder and enter your LinkedIn username, password to login and OpenAI API Key for generation of job tailored resumes and cover letters (This entire step is optional). If you do not provide username or password or leave them as default, it will login with saved profile in browser, if failed will ask you to login manually. - Open
settings.py
file in/config
folder to configure the bot settings like, keep screen awake, click intervals (click intervals are randomized to seem like human behavior), run in background, stealth mode (to avoid bot detection), etc. as per your needs. - (Optional) Don't forget to add you default resume in the location you mentioned in
default_resume_path = "all resumes/default/resume.pdf"
given in/config/questions.py
. If one is not provided, it will use your previous resume submitted in LinkedIn or (In Development) generate custom resume if OpenAI APT key is provided! - Run
runAiBot.py
and see the magic happen. - If you have questions or need help setting it up or to talk in general, join the github server: https://discord.gg/fFp7uUzWCY
Thank you for your efforts and being a part of the community. All contributions are appreciated no matter how small or big. Once you contribute to the code base, your work will be remembered forever.
NOTE: Only Pull request to community-version
branch will be accepted. Any other requests will be declined by default, especially to main branch.
Once your code is tested, your changes will be merged to the main
branch in next cycle.
- All functions or methods are named lower case and snake case
- Must have explanation of their purpose. Write explanation surrounded in
''' Explanation '''
under the definitiondef function() -> None:
. Example:def function() -> None: ''' This function does nothing, it's just an example for explanation placement! '''
- The Types
(str, list, int, list[str], int | float)
for the parameters and returns must be given. Example:def function(param1: str, param2: list[str], param3: int) -> str:
- Putting all that together some valid examples for function or method declarations would be as follows.
def function_name_in_camel_case(parameter1: driver, parameter2: str) -> list[str] | ValueError: ''' This function is an example for code guidelines ''' return [parameter2, parameter2.lower()]
- The hashtag comments on top of functions are optional, which are intended for developers
# Comments for developers
.# Enter input text function def text_input_by_ID(driver: WebDriver, id: str, value: str, time: float=5.0) -> None | Exception: ''' Enters `value` into the input field with the given `id` if found, else throws NotFoundException. - `time` is the max time to wait for the element to be found. ''' username_field = WebDriverWait(driver, time).until(EC.presence_of_element_located((By.ID, id))) username_field.send_keys(Keys.CONTROL + "a") username_field.send_keys(value)
- All variables must start with lower case, must be in explainable full words. If someone reads the variable name, it should be easy to understand what the variable stores.
- All local variables are camel case. Examples:
jobListingsElement = None
localBufferTime = 5.5
- All global variables are snake case. Example:
total_runs = 1
- Mentioning types are optional.
localBufferTime: float | int = 5.5
- All config variables are treated as global variables. They have some extra guidelines.
- Must have variable setting explanation, and examples of valid values. Examples:
# Explanation of what this setting will do, and instructions to enter it correctly config_variable = "value1" # <Valid values examples, and NOTES> "value1", "value2", etc. Don't forget quotes ("")
# Do you want to randomize the search order for search_terms? randomize_search_order = False # True of False, Note: True or False are case-sensitive
# Avoid applying to jobs if their required experience is above your current_experience. (Set value as -1 if you want to apply to all ignoring their required experience...) current_experience = 5 # Integers > -2 (Ex: -1, 0, 1, 2, 3, 4...)
# Search location, this will be filled in "City, state, or zip code" search box. If left empty as "", tool will not fill it. search_location = "United States" # Some valid examples: "", "United States", "India", "Chicago, Illinois, United States", "90001, Los Angeles, California, United States", "Bengaluru, Karnataka, India", etc.
- Add the config variable in appropriate
/config/file
. - Every config variable must be validated. Go to
/modules/validator.py
and add it over there. Example: For config variablesearch_location = ""
found in/config/search.py
, string validation is added in file/modules/validator.py
under the methoddef validate_search()
.def validate_search() -> None | ValueError | TypeError: ''' Validates all variables in the `/config/search.py` file. ''' check_string(search_location, "search_location")
- All contributions require proper attestion. Format for attestation:
##> ------ <Your full name> : <github id> OR <email> - <Type of change> ------
print("My contributions 😍") # Your code
##<
- Examples for proper attestation: New feature example
##> ------ Sai Vignesh Golla : godsscion - Feature ------
def alert_box(title: str, message: str) -> None:
'''
Shows an alert box with the given `title` and `message`.
'''
from pyautogui import alert
return alert(title, message)
##<
Bug fix example
def alert_box(title: str, message: str) -> None:
'''
Shows an alert box with the given `title` and `message`.
'''
from pyautogui import alert
##> ------ Sai Vignesh Golla : saivigneshgolla@outlook.com - Bug fix ------
return alert(message, title)
##<
(I'm yet to complete the documentation, I'm adding in more features, still in development)
- Opens browser with default logged in google account (Yet to test with browsers having multiple profiles)
- Auto Login: If configured or already saved in browser (not saved passwords)
- Apply filters (Salary, Companies, Experience Level,... ) Must config
- Region specific searches
- Opens job search and searches key words
- Easy applies
- Auto Answers questions answered in config
- Collects urls of career page if have to Apply externally
- Collects HR Info
- Collects skills required (In Development)
- Collects experience required and skips if not applicable to you, must be configured
- Auto Filters jobs based on your experience and black list key words
- Skips blacklisted jobs
- Can be configured to skip jobs requiring Security Clearance
- You can add exceptions to blacklist key words
- Only applies to filtered jobs
- Auto selects next pages until it hits the quota you configured
- Selects your default resume
- Auto Submits
- Saves all the info of applied jobs, failed to apply jobs in excels and logs
- Takes screenshot of questions answered to fail, for future debugging
- Saves info of all questions, it's options, previous answer and current answer in application
- Option to overwrite previous answers
- Continuous applications non stop (beta)
- No need for fear of missing out, Goes through all possible filters and sorts combinations with each cycle if configured (Most Recent, Most Relevant, Newest First, Past 24 Hrs, Past Month, Past Week etc)
- Option to randomize the search order
- Run in background, headless browser
- Auto collects a looooooooooooooooooot of info about your jobs, check applied-jobs.excel and failed_jobs.excel for info after each run.
- Optional pause before submit application.
- Optional pause if stuck at a question.
- Undetected Chromedriver to bypass anti-bot scripts (Browser, Undetected ChromeDriver versions must be compatible) (Beta) {If problem occurs uninstall and install undetected chromedriver, update browser, selenium and chromedriver}
- Click intervals can be randomized and increased to avoid suspicions
- Smooth Scrolls the elements into view before click
- Answer questions with help of chatGpt or other LLMs
- Humanize clicks and mouse movements for stealth
- Auto send personalized messages to HR that accept messages
- Custom resume generator based on Skills required gathering (In Development)
- Customize resume for every job using LLMs ChatGPT (In Development). (Halted decision pending, will probably implement api or utilize other LLMs or Web Scrape)
- All ChatGPT features:
- ChatGPT Login
- ChatGPT resume chat window opener
My Dear User,
Thank you for using the job application tool! Your support means everything to me.
As you continue your job search, I hope this tool has provided you with valuable assistance and streamlined your efforts.
To continue improving and maintaining this tool, I rely on the support of users like you. If you believe in its mission and want to contribute, you can support me by sharing about this project with your peers and network.
If you need a post to communicate about it: https://www.linkedin.com/posts/saivigneshgolla_jobsearch-jobapplication-careerdevelopment-activity-7166416367628341249-WE_8
By doing so, you can empower others in their job hunt, just as you've been empowered.. Every contribution, big or small, makes a significant impact!
As an independent developer, I pour my heart and soul into creating tools like this, driven by the genuine desire to make a positive impact. Your support, whether through donations or simply spreading the word, means the world to me and helps keep this project alive and thriving.
You can connect and reach me out at:
- LinkedIn : https://www.linkedin.com/in/saivigneshgolla/
- Email : saivigneshgolla@outlook.com
Thank you for being part of this journey, and remember that together, we can make a real difference in the lives of job seekers worldwide.
With heartfelt appreciation,
Sai Vignesh Golla
- Patched to work for latest changes in Linkedin.
- Users can now select to follow or not follow companies when submitting application.
- Frameworks for future AI Developments have been added.
- AI can now be used to extract skills from job description.
- Framework for OpenAI API and Local LLMs
- Framework for RAG
- Smarter Auto-fill for salaries and notice periods
- Robust Search location filter, will work in window mode (No need for full screen)
- Better logic for Select and Radio type questions
- Proper functioning of Decline to answer questions in Equal Employment opportunity questions
- Checkbox questions select fail bug fixed
- Annotations are clearer in instructions for setup
- Annotations for developers
- Robust input validations
- Restructured config file
- Fixed pagination bug
- Performance improvements (skip clicking on applied jobs and blacklisted companies)
- Stop when easy apply application limit is reached
- Added ability to discard from pause at submission dialogue box
- Added support for address input
- Bug fixed radio questions, added support for physical disability questions
- Added framework for future config file updates
- Major Bug fixes (Text Area type questions)
- Made uploading default resume as not required
- Added functionality for textarea type questions
summary
,cover_letter
(Summary, Cover letter); checkbox type questions (acknowledgements) - Added feature to skip irrelevant jobs based on
bad_words
- Improved performance for answering questions
- Logic change for masters students skipping
- Change variable names
blacklist_exceptions
->about_company_good_words
andblacklist_words
->about_company_bad_words
- Added session summary for logs
- Added option to turn off "Pause before Submit" until next run
- For questions similar to "What is your current location?", City posted in Job description will be posted as the answer if
current_city
is left empty in the configuration - Added option to over write previously saved answers for a question
overwrite_previous_answers
- Tool will now save previous answer of a question
- Tool will now collect all available options for a Radio type or Select type question
- Major update in answering logic for Easy Apply Application questions
- Added Safe mode option for quick stable launches
safe_mode
- Added option to fill in "City, state, or zip code" search box
search_location
- Bug fixes in answering City or location question
This program is for educational purposes only. By downloading, using, copying, replicating, or interacting with this program or its code, you acknowledge and agree to abide by all the Terms, Conditions, Policies, and Licenses mentioned, which are subject to modification without prior notice. The responsibility of staying informed of any changes or updates bears upon yourself. For the latest Terms & Conditions, Licenses, or Policies, please refer to Auto Job Applier. Additionally, kindly adhere to and comply with LinkedIn's terms of service and policies pertaining to web scraping. Usage is at your own risk. The creators and contributors of this program emphasize that they bear no responsibility or liability for any misuse, damages, or legal consequences resulting from its usage.
Please consider the following:
-
LinkedIn Policies: LinkedIn has specific policies regarding web scraping and data collection. The responsibility to review and comply with these policies before engaging, interacting, or undertaking any actions with this program bears upon yourself. Be aware of the limitations and restrictions imposed by LinkedIn to avoid any potential violation(s).
-
No Warranties or Guarantees: This program is provided as-is, without any warranties or guarantees of any kind. The accuracy, reliability, and effectiveness of the program cannot be guaranteed. Use it at your own risk.
-
Disclaimer of Liability: The creators and contributors of this program shall not be held responsible or liable for any damages or consequences arising from the direct or indirect use, interaction, or actions performed with this program. This includes but is not limited to any legal issues, loss of data, or other damages incurred.
-
Use at Your Own Risk: It is important to exercise caution and ensure that your usage, interactions, and actions with this program comply with the applicable laws and regulations. Understand the potential risks and consequences associated with web scraping and data collection activities.
-
Chrome Driver: This program utilizes the Chrome Driver for web scraping. Please review and comply with the terms and conditions specified for Chrome Driver.
Copyright (C) 2024 Sai Vignesh Golla saivigneshgolla@outlook.com
This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License along with this program. If not, see https://www.gnu.org/licenses/.
See AGPLv3 LICENSE for more info.
- LinkedIn : https://www.linkedin.com/in/saivigneshgolla/
- Email : saivigneshgolla@outlook.com
- X/Twitter: https://x.com/gods_scion
- Discord : godsscion
- Discord Server : https://discord.gg/fFp7uUzWCY
- GitHub