KOHighlights (KH) is a powerful highlight manager, designed to work seamlessly with KOReader, a popular open-source e-book reading software.
KH provides a robust solution for viewing, editing, synchronizing, and exporting your KOReader highlights across multiple devices.
It supports highlight synchronization and merging, enabling concurrent highlights of the same book on several KOReader devices such as e-ink readers, android phones, or linux desktops.
Periodically, all devices would need to be connected to a PC running KH, at which time, the program will merge all highlights across the connected devices irrespective of the time they were created.
Additionally, one can create an archived copy stored in KH’s internal database as a backup or as a way to have it handy, without the need of a reader connection.
Note, KOReader usually stores the epub book metadata information including the highlights and comments in metadata.epub.lua
files (a.k.a. “metadata”).
These files are automatically created by KOReader for each epub book and kept in .sdr folders with the same names as the corresponding epub files.
While using KOHighlights, keep in mind that most of the user interface controls have a Tooltip that briefly explains what they do.
This Tooltip is shown when you hover your mouse over the corresponding control.
The main toolbar of KH contains three types of buttons:
A. Source buttons – used to select sources of book’s metadata
B. Views buttons – used to switch between interface Views
C. Action buttons – used to execute specific functionality of the program
There are two sources from which KH can load highlights and other metadata:
Directly from the metadata files on connected devices or on local drives (located in .sdr folders), or
Copies of metadata files stored in the KH’s internal database (provided that the user manually archived these copies of metadata, internally)
Use “Loaded” button to set the connected devices/drives as the source.
Use “Archived” button to set the KH’s database as the source.
KH can present book metadata in either Books or Highlights layout view.
These views are explained in more detail later in this guide.
In addition, there is a special Sync Groups view, used to synchronize highlights across multiple devices running KOReader.
Depending on the metadata source and the specific View selected, KH will display/hide and/or activate/deactivate the action buttons that are appropriate for the given context.
The action buttons execute KH functionality as described in their corresponding sections.
As the name implies, the Books View is a layout used to display the content of the e-book metadata files created in KOReader.
The Books View is accessible for both the Loaded and Archived sources of metadata.
This layout has three panels: Book Selector, Book Information and Highlights.
The Book Selector panel displays all loaded books in a table, with several columns showing the book’s Name, Author, Type, Percentage read, last modified date, the number of highlights captured in the metadata file and more.
The Book Info panel provides additional information for the select book such as Book Series, Tags, Language and Description.
The Highlights panel shows the selected book’s highlights and comments.
.sdr
metadata folders of books, for scanning. Could be a reader’s partition or a folder somewhere on a hard drive.Put the source selector button (8) into the “Loaded” position
Click the “Scan Directory” button (1)
Navigate to the directory containing your KOReader metadata files
Click on the Select Directory button
KH will search for all metadata.lua files that are inside this directory and all subdirectories, and display the book names in the Book Selector panel
Select a book in the book selector panel (KH will highlight your selection)
Browse the highlights and comments in the Highlights panel
Customize how highlights are displayed using the Preferences dialog (press the “Preferences” button (9) to show)
Note the Highlight Options specified in the Preferences dialog also impact what will be included / excluded when using the Export feature.
Double-click on the highlight you want to edit its comment
Type something or edit the existing text
Press OK to save the changes, Cancel to discard them
Your edits will be directly applied to (written into) the book’s metadata file
For clarity, the highlights themselves must be created in KOReader and cannot be created/edited with KH.
However, you can create/edit notes (comments) of the highlights both in KOReader and KH.
Click on the highlight you want to delete to select it (use ctrl+ click to select multiple entries)
Right-click on the selection and chose “Delete”
When KH displays a warning, click “Yes” to proceed and “No” to cancel
Warning: Do not use any of the options under the Delete button in the toolbar to delete specific highlights!
Those options are used only to delete the entire metadata file for the book or even the underlying epub book file too.
Note, if you are using KH to synchronize highlights across devices, the deleted highlights may be restored during the next synchronization, if other devices in the same Sync Group still contain the deleted highlights.
This is because the synchronization process looks for the current differences inside the metadata files.
The deleted entries are viewed by the program as missing highlights that must be synced/added to the metadata that misses them.
If you want to delete certain highlights and comments on one device and then propagate your deletions to other devices (in the given sync group), use the workaround described in the Replacing book metadata with Archived copy under III. Sync Groups View section of this guide.
Use the “Filter” button (4) to open a dialog you can use to filter the content of the current View by some specified keywords.
Only book entries that contain these words will be displayed.
Select a book in the selector panel
Click on the View button (3) or double-click anywhere on the book’s row, to view the epub in your system’s default viewer
Select a book in the selector panel (use ctr+click to select multiple books)
Click on the Delete button (6) to display the drop-down menu
Select the desired option from the list
To delete the book’s metadata file use the “Selected book’s info” option
To delete the book’s .epub file(s) use the “Selected books” option
To delete the metadata files that do not have their corresponding .epub/.pdf/etc. files, use the “All missing books info” option
Press “Clear List” button (7) to clear the Book Selection panel.
Note, this action doesn’t remove or delete any actual epub or metadata files from your system.
Use “Scan Directory” button to repopulate the list (see Scanning for Books), or drag and drop any folder that contains book metadata.
Tip: To only remove one or a few entries from the panel, select them and just press the Delete
button. No physical files will be deleted from the device/drive.
KH can export highlights to text, html, csv, and markdown formats.
Optional: Use the “Preferences” options to customize the way the highlights should look.
This will also affect the way the exported files will look like.
If the highlights are displayed OK, then the steps to actually export them are:
Select the book (or books) to export in the Book selector by clicking on them.
(While in the Books View, exporting a book’s highlights will export all the highlights that are included in the book)
Click on the “Export” button and select the desired format from the drop-down menu.
Specify the destination folder for the exported file(s) in the dialog.
KH includes a custom template creation feature, that you can use to tweak the appearance of the highlights exported into the Markdown format.
Check the “Custom Markdown” checkbox under “Preferences” dialog, to activate the option.
Customize the template by clicking on the “Edit” button.
Enter the variables into the parameter panels on the left side of the “Edit Markdown template” dialog (1).
The outcome will be reflected in the preview panels on the right side (2)
Exporting with collapsible TOC levels
This is an experimental feature designed to work with “2-save-full-chapter-path.lua” user patch.
With this user patch installed, the highlights created in the KOReader metadata’s “chapter” key will contain the full path from the book’s Table of Content separated by the “▸” character.
The Highlights View is designed to present highlights from all loaded books in a single grid. This format is useful when one wants to view highlights across several books.
Alternatively, one can compare the highlights from the same book but located on several devices .
The Highlights View has a single panel with several columns that one can re-arrange in the desired order.
All columns are sortable. Click on the column headers to sort the content either in the ascending or the descending order.
Most of the action buttons under the Highlights View look and behave the same way as under the Books View.
However, there some notable differences to be aware of:
The “Export” button will export only the selected highlights, rather than including all highlights in a selected book as under the Books view.
Also, this button doesn’t have the drop-down menu to select the format of the export. Once you press the button, one would specify the exported file destination in the dialog window as well as select the desired format under the “Save as Type” drop down.
The “Delete” button doesn’t have a drop-down selector as in the Books view, and what it does is to delete all the selected highlights.
The Delete
button of the keyboard also performs the same function.
This layout is designed to simplify highlight synchronization tasks across several devices running KOReader.
KH can synchronize (merge) highlights / reading positions between:
Connected KOReader devices or local drives (required access to the book metadata folders)
These can also be copies of folders that exist in devices that can expose their internal storage as a local drive to a PC (like modern Android phones).
KH’s Internal database copy (archive)
(1) Add a new group (KH will create a new empty group at the bottom of the group list)
(2) Sync all groups (KH will synchronize all active Sync Groups at once)
(3) Delete selected group(s) (also available via right-click menu)
(4) Refresh the source files (KH will re-read the metadata files specified in the Sync Paths of the selected group)
(5) Sync Position (check this box to sync the reading positions)
(6) Merge Highlights (KH will merge the highlights and comments across the members of the group)
(7) Sync with archived (KH will update the archived version in its internal database)
(8) The name of the Sync Group (typically the same as the book’s title). The group can be renamed via right-click menu
(9) Sync this group: KH will only sync this group, not any other group. Same is available via right-click menu
(10) Add / Remove a member of the Sync Group
(11) Show/Hide the group members’ paths
(12) Select / Change the file path pointing to book metadata files (e.g. after adding a new member to the group)
(13) Path error (red color indicates an issue with the file)
(14) Toggle the Sync Group active / inactive. Only active groups are synced when used Sync All (2)).
Note, that you can re-arrange the Sync Groups order by dragging specific groups to the desired position.
Right-clicking on a sync group will bring up the following menu:
Rename group - Allows to change the name of the Sync Group
Sync group - Same as the “Sync this group” button (9)
Load group items - Will load all metadata files in a group in the Books view
Copy Archived to group
Caution! Using this feature will overwrite all highlights in the group files with the archived version stored in KH database.
This feature can also be used when you edited the archived version of the book, and you want to propagate it to all devices.
Delete selected - Same as the “Delete” button (3).
Click the “Select” button (11) to locate the book’s metadata file on device 1. KH will read the book’s metadata file and automatically assign the book’s title as the name for this sync group.
Rename the group if desired by right-clicking and selecting “Rename group”.
Click the “Plus” button (10) to add a new path
Click the “Select” button (12) to locate the book’s metadata file on device 2.
Repeat steps “3” and “4” for other connected devices if any.
“Sync Position” (5) to sync reading positions across devices.
“Merge Highlights” (6) to combine highlights and comments from all devices.
“Sync with archived” (7) to copy an updated version to KH’s internal database.
Ensure all groups you want to sync are set to active using the toggle switch (14).
Click the “Sync all groups” button (2).
KH will display a message informing if the sync was successful.
Locate the toggle switch (14) next to the group you want to activate or deactivate.
Click the switch to toggle between active and inactive states.
Note, that only active groups will be synced when using the “Sync all groups” function.
Select the desired group from the list.
Click the “Sync this group” button (9) or right-click and select “Sync this group”.
KH will display a message informing if the sync was successful.
Select the group(s) you want to delete.
Click the “Delete selected group(s)” button (3) or right-click and select “Delete group”.
Look for red-colored file paths (13) in your sync groups.
Check if the file exists and is accessible at the specified location.
If the file is missing or inaccessible, locate the correct file and update the path.
Click the “Refresh the source files” button (4) to re-read the updated path.
If the error persists due to MD5 mismatch, refer to the Advanced Features section for MD5 correction methods.
KH can replace the book metadata files for the selected sync group, with the most recent archived copy.
Press the “Archived” button to view the database books
Select the book to make sure it contains the desired set of highlights
Make changes if required (e.g. edit comments or delete entire highlights)
Go to the Sync Groups View
Right-click on the Sync Group containing the book
Select “Copy Archived to Group” (this will display a warning dialog)
Click OK to accept
Right-clicking or pressing the arrow at the right edge of the “Archived” button, will present the database menu.
The following options are available:
data.db
file. With this action we can create a different database file to store a different group of book metadata.To quickly change the current database, you can drag a database file (.db
) from the explorer, and drop it on the Book Selector panel of the Books View, while in the database mode (the “Archived” button pressed)
There is a common reason why the MD5 checksum between two seemingly identical files, can be different.
One of them, has been re-saved.
Let’s say we copy the same epub
file to our reader and keep a copy at our PC.
Then, we open the file on our PC with an editor to change a minor detail in the book.
Or we don’t edit the file at all. Just read it with a software that saves the reading position inside the file itself (like older and perhaps also current(?) versions of Calibre).
In every case, the book gets re-saved, and the re-saved book is a totally different file than the one in our reader.
The reason the MD5 check exists is that, if we try to sync the highlights of different books, all sorts of strange things can (and will) happen.
But if we’re absolutely sure that nothing has actually changed in the contents of the epub, then, there is a way to bypass the MD5 check.
Warning! Use this at your own risk!
If there is an MD5 mismatch, you can right-click the erroneous sync path (13) and select “Ignore MD5” on the popup menu.
This will create an empty ignore_md5
file next to the metadata file, and will allow sync to proceed.
Right-clicking again on this path, will give you the option to delete the ignore_md5
file by un-checking the “Ignore MD5” option.
Note, this is an experimental feature designed to work with “2-save-full-chapter-path.lua” user patch.
With the user patch installed, the highlights created in the KOReader metadata’s “chapter” key, will contain the full path from the book’s Table of Content, separated by the “▸” character as follows:
[chapter] = "Some chapter ▸ Some sub-chapter ▸ Some sub-sub-chapter"
When this feature is being utilized during the export, KH will split the TOC path into individual levels and map each to its corresponding markdown heading (##, ###, ####, etc.) producing a clean hierarchical structure.
The following is an example of the output presented in Obsidian:
To export to markdown with collapsible TOC levels, follow the following steps:
Pre-requisite: The exported highlights were taken with the user patch already installed (validate by navigating to the book’s metadata file (located in the corresponding .sdr folder)).
Make sure the “chapter” key contains full path headings in the format:
[chapter] = "Heading L1 ▸ Heading L2 ▸ Heading L3"
Click on the Settings button to open the dialog
Select “Custom Markdown” checkbox
Right-click on the “Edit” button next to the “Custom Markdown” checkbox.
This will open the “Edit Markdown Template” dialog like the normal click would, but with a notable difference.
At the bottom of the dialog window there will be a checkbox called “Split Chapters” with the level selectors from Levels 1 to Level 6
Customize the template to reflect your preferences. In the screenshot above, the template will map the book’s name to the Heading 1 and assign Headings 2 to 6 to other TOC levels. The highlights will appear under the pages numbers (in p-{page#} format) and will also use Obsidian’s “Quote” callout ‘>[!quote]’ . The comments will appear in Italics.
Press “OK” and finalize the export by following the prompts
local ReaderAnnotation = require("apps/reader/modules/readerannotation")
local ReaderToc = require("apps/reader/modules/readertoc")
ReaderToc.getFullTocTitleByPage = ReaderToc.getFullTocTitleByPage or function(self, pn_or_xp)
local chapters = {}
local toc_ticks_ignored_levels_orig = {}
local toc_chapter_title_bind_to_ticks_orig = self.toc_chapter_title_bind_to_ticks -- backup the flag
self.toc_chapter_title_bind_to_ticks = true -- honor self.toc_ticks_ignored_levels
local max_depth = self:getMaxDepth()
for depth = max_depth, 1, -1 do
toc_ticks_ignored_levels_orig[depth] = self.toc_ticks_ignored_levels[depth] -- backup the level
-- ignore the level if it should be ignored due to original settings
self.toc_ticks_ignored_levels[depth] = self.toc_ticks_ignored_levels[depth] and toc_chapter_title_bind_to_ticks_orig
local chapter = self:getTocTitleByPage(pn_or_xp)
if chapter ~= "" and chapter ~= chapters[1] then
table.insert(chapters, 1, chapter)
end
self.toc_ticks_ignored_levels[depth] = true -- ignore the level on next iterations
end
self.toc_chapter_title_bind_to_ticks = toc_chapter_title_bind_to_ticks_orig -- restore the flag
table.move(toc_ticks_ignored_levels_orig, 1, max_depth, 1, self.toc_ticks_ignored_levels) -- restore all levels
return chapters
end
ReaderAnnotation.addItem_orig = ReaderAnnotation.addItem
ReaderAnnotation.addItem = function(self, item)
item.chapter = table.concat(self.ui.toc:getFullTocTitleByPage(item.page), " ▸ ")
return self:addItem_orig(item)
end
For KOReader versions after 2024.07 use:
local ReaderAnnotation = require("apps/reader/modules/readerannotation")
ReaderAnnotation.addItem_orig = ReaderAnnotation.addItem
ReaderAnnotation.addItem = function(self, item)
item.chapter = table.concat(self.ui.toc:getFullTocTitleByPage(item.page), " ▸ ")
return self:addItem_orig(item)
end
Then, place the file into your KOReader’s “patches” directory.