transform arXiv papers into a single latex prompt for LLMs
Project description
A command-line tool to transform arXiv papers into a single LaTeX source that can be used as a prompt for asking LLMs questions about the paper. It downloads the source files, automatically finds the main tex file containing \documentclass, and flattens multiple files into a single coherent source by resolving \input and \include commands. The tool also provides options to remove LaTeX comments and appendix sections from the output (which can be useful to shorten the prompt).
Installation
pip install arxiv-to-prompt
Usage
# Display LaTeX source
arxiv-to-prompt 2303.08774
# Display LaTeX source without comments
arxiv-to-prompt 2303.08774 --no-comments
# Display LaTeX source without appendix sections
arxiv-to-prompt 2303.08774 --no-appendix
# Combine options (no comments and no appendix)
arxiv-to-prompt 2303.08774 --no-comments --no-appendix
# Copy to clipboard
arxiv-to-prompt 2303.08774 --copy # or -c
You can use either the arXiv ID (e.g., 2303.08774) or the full URL (e.g., https://arxiv.org/abs/2303.08774). It will automatically download the most recent version of the paper, so you don't need to specify the version. Downloaded papers are cached locally, so subsequent runs for the same paper will use the cached version without re-downloading.
Advanced Options
# Force re-download even if the paper is already cached
arxiv-to-prompt 2303.08774 --force-download
# Process a local folder containing TeX files (instead of downloading from arXiv)
arxiv-to-prompt --local-folder /path/to/tex/files
# Cache locking is on by default (120s timeout); increase/decrease it if needed
arxiv-to-prompt 2303.08774 --lock-timeout 300
# List all sections (with subsections indented)
arxiv-to-prompt 2307.09288 --list-sections
# Introduction
# Pretraining
# Pretraining Data
# Training Details
# Training Hardware \& Carbon Footprint
# ...
# Extract specific sections
arxiv-to-prompt 2307.09288 --section "Introduction" --section "Pretraining"
# Ambiguous names show a helpful error
arxiv-to-prompt 2307.09288 --section "Human Evaluation"
# Warning: 'Human Evaluation' is ambiguous. Found at:
# - Fine-tuning > RLHF Results > Human Evaluation
# - Appendix > Additional Details for Fine-tuning > Human Evaluation
# Use path notation to disambiguate.
# Use path notation when the same name appears multiple times
arxiv-to-prompt 2307.09288 --section "Fine-tuning > RLHF Results > Human Evaluation"
# Output figure file paths instead of LaTeX text
arxiv-to-prompt 2303.08774 --figure-paths
# Figure paths from main body only (exclude appendix and commented-out figures)
arxiv-to-prompt 2303.08774 --figure-paths --no-appendix --no-comments
# Output only the abstract text
arxiv-to-prompt 2303.08774 --abstract
# Expand \newcommand and related macro definitions inline
arxiv-to-prompt 2303.08774 --expand-macros
# Print token count (requires pip install 'arxiv-to-prompt[tokens]')
arxiv-to-prompt 2303.08774 --token-count
# 94253
# Combine with other flags to see how they affect token count
arxiv-to-prompt 2303.08774 --no-comments --no-appendix --token-count
# 62451
# Combine with the `llm` library from https://github.com/simonw/llm to chat about the paper
arxiv-to-prompt 1706.03762 | llm -s "explain this paper"
Python API
You can also use arxiv-to-prompt in your Python code:
from arxiv_to_prompt import process_latex_source
# Get LaTeX source with comments
latex_source = process_latex_source("2303.08774")
# Get LaTeX source without comments
latex_source = process_latex_source("2303.08774", keep_comments=False)
# Get LaTeX source without appendix sections
latex_source = process_latex_source("2303.08774", remove_appendix_section=True)
# Combine options (no comments and no appendix)
latex_source = process_latex_source("2303.08774", keep_comments=False, remove_appendix_section=True)
# Force re-download even if the paper is already cached
latex_source = process_latex_source("2303.08774", use_cache=False)
# Process LaTeX sources from a local folder (instead of downloading from arXiv)
latex_source = process_latex_source(local_folder="/path/to/tex/files")
# Get resolved figure file paths instead of LaTeX text
figure_paths = process_latex_source("2303.08774", figure_paths_only=True)
# Get only the abstract text
abstract = process_latex_source("2303.08774", abstract_only=True)
# Expand custom macro definitions inline
latex_source = process_latex_source("2303.08774", expand_macros_flag=True)
# Count tokens (requires pip install 'arxiv-to-prompt[tokens]')
from arxiv_to_prompt import count_tokens
token_count = count_tokens(latex_source)
Projects Using arxiv-to-prompt
Here are some projects and use cases that leverage arxiv-to-prompt:
- arxiv-latex-mcp: MCP server that fetch and process arXiv LaTeX sources for precise interpretation of mathematical expressions in papers.
- arxiv-tex-ui: chat with an LLM about an arxiv paper by using the latex source.
- paper2slides: transform an arXiv paper into slides.
- notations-cli: extract notation tables from arXiv papers using LLMs, generating searchable HTML documentation of mathematical symbols and their definitions.
- ArXivToPrompt: iOS app that allows users to easily extract LaTeX source from arXiv papers on their iPhone and copy it to the clipboard for use with LLM apps.
- arxiv_recommender: recommendation system for arXiv papers.
- ScienceClaw: a self-evolving AI research colleague for scientists.
- ai-assistant-workspace: AI assistant workspace.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file arxiv_to_prompt-0.13.3.tar.gz.
File metadata
- Download URL: arxiv_to_prompt-0.13.3.tar.gz
- Upload date:
- Size: 32.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c23859f7c19ca021e1485e114870257913067852d61d27177d92bb0c5390975d
|
|
| MD5 |
f7c9dfcc915926c99afa3d0a95a289f8
|
|
| BLAKE2b-256 |
bcb771c5f4e8204f69333eedf6bfb2fe11d69befa0fc4a07edf70373724fe079
|
Provenance
The following attestation bundles were made for arxiv_to_prompt-0.13.3.tar.gz:
Publisher:
publish.yml on takashiishida/arxiv-to-prompt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
arxiv_to_prompt-0.13.3.tar.gz -
Subject digest:
c23859f7c19ca021e1485e114870257913067852d61d27177d92bb0c5390975d - Sigstore transparency entry: 1399495858
- Sigstore integration time:
-
Permalink:
takashiishida/arxiv-to-prompt@a6d24f6defb5cc6058a2e1d9a2f69c927ea4db78 -
Branch / Tag:
refs/tags/v0.13.3 - Owner: https://github.com/takashiishida
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@a6d24f6defb5cc6058a2e1d9a2f69c927ea4db78 -
Trigger Event:
release
-
Statement type:
File details
Details for the file arxiv_to_prompt-0.13.3-py3-none-any.whl.
File metadata
- Download URL: arxiv_to_prompt-0.13.3-py3-none-any.whl
- Upload date:
- Size: 18.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0fa7b36800091f9de8dbbd74adeebd128ac4944763cb18648e87ceacc01eb8eb
|
|
| MD5 |
90177336eab9048f5f4ad7b1e0da4590
|
|
| BLAKE2b-256 |
3e8662616762a3572d419c3407878877dcfcb878a1e0cb3e9f59383eb25cb7b7
|
Provenance
The following attestation bundles were made for arxiv_to_prompt-0.13.3-py3-none-any.whl:
Publisher:
publish.yml on takashiishida/arxiv-to-prompt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
arxiv_to_prompt-0.13.3-py3-none-any.whl -
Subject digest:
0fa7b36800091f9de8dbbd74adeebd128ac4944763cb18648e87ceacc01eb8eb - Sigstore transparency entry: 1399495862
- Sigstore integration time:
-
Permalink:
takashiishida/arxiv-to-prompt@a6d24f6defb5cc6058a2e1d9a2f69c927ea4db78 -
Branch / Tag:
refs/tags/v0.13.3 - Owner: https://github.com/takashiishida
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@a6d24f6defb5cc6058a2e1d9a2f69c927ea4db78 -
Trigger Event:
release
-
Statement type: