Skip to content

simon-rechermann/py_pdf2rmnotebook

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

py_pdf2rmnotebook

Creates a reMarkable2 rmdoc file from one or multiple PDFs having one or multipe pages. The rmdoc file can be moved to the reMarkable2 via drag and drop to the web Interface Transferring files via web Interface .

General information

This project is still in development and only tested with python3.12 on ubuntu with a remarkable2 having Software verison 3.11.2.5 installed. It should also work on windows and macOS with minor adaptions as python and java(drawj2d) are platform independent. However, I haven't tested it on other platforms so far. If you want to use it on windows raise a github issue, then I can add support for that.

Please create a backup of your files before copying the generated rmdoc file to your reMarkable. It should't break anything but just to be safe How to backup your data.

For question, improvement suggestions, bug reports etc. create a github issue.

Setup the project on a ubuntu machine (You can also use Ubuntu on a Windows Machine with WSL2 https://learn.microsoft.com/en-us/windows/wsl/install)

# Install java (jdk and jre)
# I used openjdk-21-jdk but older versions are fine as well
sudo apt install openjdk-21-jdk
# Verify that java is installed
╰─➤  java --version
openjdk 21.0.3 2024-04-16
OpenJDK Runtime Environment (build 21.0.3+9-Ubuntu-1ubuntu122.04.1)
OpenJDK 64-Bit Server VM (build 21.0.3+9-Ubuntu-1ubuntu122.04.1, mixed mode, sharing)
# Download drawj2d
# I used the debian package (drawj2d_1.3.3-4.1_all.deb), if you are on other operating systems, use the .zip file, download it, unzip it and add drawj2d to the PATH so you operating system finds it
cd ~/Downloads
sudo dkpg -i drawj2d_1.3.3-4.1_all.deb # the debian package get's installed to a location that part of the PATH so no further adjustments are necessary
# Verify the installation
╰─➤  drawj2d                                                                                                      130 ↵

            Welcome to Drawj2d
            Copyright (c) A. Vontobel, 2014-2024
            Version 1.3.3

Mode: Freehep
  • Setup the python project
sudo apt update
# Install python3, python3-venv, python3-pip
sudo apt install python3 python3-venv and python3-pip
# Clone the repo and cd into it
git clone https://github.com/simon-rechermann/py_pdf2rmnotebook.git
cd py_pdf2rmnotebook
# Setup a python virtual environment
python3 -m venv venv
# Activate the venv. This has to be done each time you start a new shell!
source venv/bin/activate
# Install the requirements
pip install -r requirements.txt

Setup the project on a windows machine

  • Download java (e.g. the openJDK from here https://adoptium.net/) and execute the installer -> Select "Add to PATH" and "Set JAVA_HOME variable" in the installer and install it -> To vertify that the installation worked open a Powershell and type java --version
java --version # the command should return the openJDK version (the version itself does not matter)
openjdk 21.0.3 2024-04-16 LTS
OpenJDK Runtime Environment Temurin-21.0.3+9 (build 21.0.3+9-LTS)
OpenJDK 64-Bit Server VM Temurin-21.0.3+9 (build 21.0.3+9-LTS, mixed mode, sharing)
  • Install drawj2d drawj2d Download the zip file and unpack it to a location that you like
  • Add drawj2d to the PATH How to add something to the PATH in windows -> I unpacked the zip file to my Documents folder so I had to add C:\Users\simon\Documents\Drawj2d-1.3.3\Drawj2d to the PATH -> To vertify that the installation worked open a Powershell and type drawj2d (AFTER YOU ADDED SOMETHING TO THE PATH RESTART THE POWERSHELL)
drawj2d

            Welcome to Drawj2d
            Copyright (c) A. Vontobel, 2014-2024
            Version 1.3.3

Mode: Freehep
  • Download the py_pdf2rmnotebook zip file py_pdf2rmnotebook zip file and unpack it (You can also use git of course to clone the repo if you want)
  • Open powershell
# Install python
python # this will open the Microsoft Store where you can download python
# Test the installation -> the python --version command should return the version 
python --version 
Python 3.12.4  # Other versions should be file as well
cd <path_to_py_pdf2rmnotebook> # go to the location where you unpacked the py_pdf2rmnotebook
Set-ExecutionPolicy Unrestricted -Scope Process
python -m venv venv
.\venv\Scripts\Activate.ps1
pip install -r .\requirements.txt
python .\pdf2rmnotebook.py <pdf>

Usage

# Make sure you sourced the venv so python knows it's requirements/site-packages!
# Get help message that shows usage
python3 pdf2rmnotebook.py -h

Example

I have two PDFs (document1.pdf and document2.pdf) with each of them having 3 pages stored at py_pdf2rmnotebook/pdfs.

# Execute pdf2rmnotebook.py with the two PDFs
python3 pdf2rmnotebook.py pdfs/document1.pdf pdfs/document2.pdf

The result is stored at py_pdf2rmnotebook/output. To move the notebook to your reMarkable2 you have to drag and drop the file py_pdf2rmnotebook/output/document1.rmdoc into the web Interface. By default the rmdoc name and the name of the notebook that will appear on your reMarkable is the name of the first pdf you passed to the program (in this case document1).

Limitations

The amout of pdf pages respectively the size of the rmdoc file you drag and drop is currently limited to a size of 100MB https://support.remarkable.com/s/article/Importing-files

This is approximately 20 PDF pages (depending on the scale you choose). The quality of the thumbnails images of the notebook pages is already reduced pretty much. The limiting factor is the size of the notebook pages created with drawj2d.

About

A python program to convert PDFs to reMarkable Notebooks

Resources

Stars

Watchers

Forks

Packages

No packages published