No description
Find a file
2025-01-08 14:30:05 +09:00
src/browser_history_merger update error handling for not registered browser 2025-01-08 14:30:05 +09:00
.gitignore init commit with init add subcommands 2024-06-07 18:07:10 +09:00
.python-version update python version (system@3.13.1) 2025-01-08 14:29:40 +09:00
CHANGELOG.md update documents 2024-06-09 17:13:57 +09:00
pyproject.toml init commit with init add subcommands 2024-06-07 18:07:10 +09:00
README.md add sql example 2024-06-09 18:11:43 +09:00
requirements-dev.lock update python version (system@3.13.1) 2025-01-08 14:29:40 +09:00
requirements.lock update python version (system@3.13.1) 2025-01-08 14:29:40 +09:00

browser-history-merger

Merge browser histories into a single database.

Usage

Initialization

For the first execution on each device and browser, do

browser-history-merger path/to/merged.db init browser-id /abs/path/to/browser/history/database

browser-id should be unique to identify browser and machine.

Add histories

Then add histories to the database by

browser-history-merger path/to/merged.db add browser-id

Supported environments

Python 3.12 (works with standard libraries only)

  • Chromium
    • Tested:
      • chrome on windows, linux
      • brave on windows, linux
      • vivaldi on linux
  • Firefox
    • Tested:
      • firefox on windows

Tips

The program is a single file ./src/browser_history_merger/__init__.py and can be used as a script.

Example SQL to see the history

SELECT
	browsers.name,
	visits.title,
	visits.url,
	datetime(visits.visit_time / 1000000 - 11644473600, 'unixepoch')
FROM
	visits,
	browsers
WHERE
	visits.browser = browsers.id
ORDER by
	visits.visit_time
	DESC LIMIT 0, 100

Todo

  • exporting
    • JSON output
    • browser list
  • multiple profiles?