Installation:
pip install pyserpzotero
Resource | URL |
---|---|
Docs | https://pyserpzotero.readthedocs.io |
GitHub Repo | https://github.com/hack-r/pyserpZotero |
PyPI Package | https://pypi.org/project/pyserpZotero/ |
SerpAPI | https://serpAPI.com |
Zotero | https://zotero.org |
ArXiv, BioRxiv, and MedRxiv do not require configuration, although they can be disabled in the config file. You'll need to provide an API key for serpAPI and Zotero, as well as a Zotero library Id. You can either provide these directly as arguments to the functions, via the interactive mode, or manage them more securely via a YAML configuration file, as in the Example Usage below.
- GUI and CLI Interfaces: Offers both a user-friendly graphical interface and a command-line interface for flexibility.
- Automated Search: Search Google Scholar and preprint servers like arXiv, medRxiv, and bioRxiv.
- Citation Management: Automatically fetches citations and uploads them to your Zotero library.
- PDF Attachment: Attempts to find and download free PDFs of the articles and attach them to the Zotero entries.
- Duplicate Avoidance: Checks your Zotero library to avoid adding duplicate entries.
pip install pyserpZotero
Ensure you have the following dependencies installed:
- Python 3.7 or higher
- Required Python packages will be installed automatically via
pip
.
Starting with version 1.2, pyserpZotero
includes a GUI application for an improved user experience.
After installation, you can start the GUI by running:
pyserpZotero_gui
- Easy Configuration: Input your SerpAPI and Zotero credentials directly in the GUI.
- Multiple Search Terms: Enter multiple search terms separated by semicolons (
;
). - Progress Monitoring: View real-time progress of your searches and downloads.
- Log Viewer: See detailed logs of the operations being performed.
- PDF Viewer: Open and view downloaded PDFs directly from the application.
For users who prefer the command line, pyserpZotero
still offers a robust CLI.
Simply run:
psz
The CLI will prompt you for:
- SerpAPI Key
- Zotero Library ID
- Zotero API Key
- Download preferences
- Search terms
Enter your SerpAPI API key:
Enter your Zotero library ID:
Enter your Zotero API key:
Enter download destination path (leave empty for current directory):
Do you want to download your citation library to avoid duplicating entries? [Y/n]:
Do you want to download PDFs? [Y/n]:
Enter the oldest year to search from (leave empty if none):
Enter the max number of searches you would like to do (leave empty for default value of 50):
Enter up to 20 search phrases separated by semi-colon(;): Cancer Research; Humanoid Robot; DNA mutation
You can provide your API keys and preferences either during the interactive prompts or by editing the config.yaml
file created in your current directory.
SERP_API_KEY: your_serpapi_key
ZOT_ID: your_zotero_library_id
ZOT_KEY: your_zotero_api_key
DOWNLOAD_DEST: ./downloads
ENABLE_LIB_DOWNLOAD: true
ENABLE_PDF_DOWNLOAD: true
NO_SERP: false
NO_ARXIV: false
NO_BIOARXIV: false
NO_MEDARXIV: false
You can configure the application to skip searching specific platforms by setting the following options in your config.yaml
:
NO_SERP: true
- Skip searching using SerpAPI (Google Scholar).NO_ARXIV: true
- Skip searching on arXiv.NO_BIOARXIV: true
- Skip searching on bioRxiv.NO_MEDARXIV: true
- Skip searching on medRxiv.
You can add multiple queries separated by semicolons (;
). The application will process each query sequentially.
The GUI includes a built-in PDF viewer. After downloading PDFs, you can open and view them directly from the application.
Make sure to have the following packages installed:
- ttkbootstrap: For enhanced GUI styling.
pip install ttkbootstrap
- PyMuPDF: For PDF viewing functionality.
pip install PyMuPDF
SerpAPI provides stable access to Google Scholar without IP throttling, ensuring that your searches are reliable and uninterrupted.
- SerpAPI Key: Sign up at SerpAPI to get your API key.
- Zotero API Key: Log in to your Zotero account and navigate to API Settings to create a new key.
Yes, SerpAPI offers a free tier which currently allows for 100 searches per month.
It's an R programming practice for readability based on major style guides (not PEP).
Contributions and forks are welcome! Please see the GitHub repository for contribution guidelines.
This project is licensed under the MIT License.