2020-01-08 08:37:17 +05:30
< h1 align = "center" > buku< / h1 >
2015-11-10 12:45:35 +05:30
2016-04-23 11:16:27 +05:30
< p align = "center" >
2020-01-08 08:37:17 +05:30
< a href = "https://github.com/jarun/buku/releases/latest" > < img src = "https://img.shields.io/github/release/jarun/buku.svg?maxAge=600" alt = "Latest release" / > < / a >
2019-12-21 07:09:01 +05:30
< a href = "https://repology.org/project/buku/versions" > < img src = "https://repology.org/badge/tiny-repos/buku.svg" alt = "Availability" > < / a >
2019-12-21 07:10:16 +05:30
< a href = "https://pypi.org/project/buku/" > < img src = "https://img.shields.io/pypi/v/buku.svg?maxAge=600" alt = "PyPI" / > < / a >
2020-01-08 08:37:17 +05:30
< a href = "https://circleci.com/gh/jarun/workflows/buku" > < img src = "https://img.shields.io/circleci/project/github/jarun/buku.svg" alt = "Build Status" / > < / a >
2017-09-10 03:43:58 +05:30
< a href = "http://buku.readthedocs.io/en/latest/?badge=latest" > < img src = "https://readthedocs.org/projects/buku/badge/?version=latest" alt = "Docs Status" / > < / a >
2019-12-21 07:09:01 +05:30
< a href = "https://en.wikipedia.org/wiki/Privacy-invasive_software" > < img src = "https://img.shields.io/badge/privacy-✓-crimson" alt = "Privacy Awareness" / > < / a >
2020-06-14 11:50:20 +05:30
< a href = "https://github.com/jarun/buku/blob/master/LICENSE" > < img src = "https://img.shields.io/badge/license-GPLv3-yellowgreen.svg?maxAge=2592000" alt = "License" / > < / a >
2016-04-23 11:16:27 +05:30
< / p >
2016-04-23 02:41:16 +05:30
< p align = "center" >
2020-10-12 17:28:36 +05:30
< a href = "https://asciinema.org/a/137065" > < img src = "https://asciinema.org/a/137065.svg" alt = "buku in action!" width = "734" / > < / a >
2016-04-23 02:41:16 +05:30
< / p >
2015-11-10 12:45:35 +05:30
2020-01-08 08:37:17 +05:30
< p align = "center" > < i > buku in action!< / i > < / p >
2017-09-11 00:01:47 +05:30
2017-03-29 12:37:43 +05:30
### Introduction
2017-03-13 10:01:35 +05:30
2020-01-08 08:37:17 +05:30
`buku` is a powerful bookmark manager written in Python3 and SQLite3. When I started writing it, I couldn't find a flexible command-line solution with a private, portable, merge-able database along with seamless GUI integration. Hence, `buku` (after my son's nickname, meaning *close to the heart* in my language).
2017-03-13 10:01:35 +05:30
2020-01-08 08:37:17 +05:30
[bukuserver ](https://github.com/jarun/buku/tree/master/bukuserver ) exposes a browsable front-end on a local web host server.
2018-04-21 18:13:11 +05:30
2019-02-11 01:47:03 +05:30
`buku` can auto-import bookmarks from your browser(s) or fetch the title and description of a bookmarked url from the web. You can use your favourite editor to compose and update bookmarks. With multiple search options, including regex and a deep scan mode (particularly for URLs), it can find any bookmark instantly. `buku` can look up the latest snapshot of a broken link on the Wayback Machine. There's an Easter egg to revisit random forgotten bookmarks too! *Buku* is too busy to track you: no hidden history, obsolete records, usage analytics or homing.
2018-11-20 09:17:12 +05:30
2020-01-08 08:37:17 +05:30
To get started right away, jump to the [Quickstart ](#quickstart ) section. We have one of the best documentation around. You'll find handy examples in the man page too. For more details, please refer to the wiki page on [operational notes ](https://github.com/jarun/buku/wiki/Operational-notes ).
2017-03-13 10:01:35 +05:30
2018-07-10 09:49:05 +05:30
There are several [projects based on `buku` ](#related-projects ), including a browser plug-in.
2017-03-13 10:01:35 +05:30
2018-07-18 01:36:13 +05:30
*Love smart and efficient utilities? Explore [my repositories ](https://github.com/jarun?tab=repositories ). Buy me a cup of coffee if they help you.*
2017-12-09 12:16:32 +05:30
2017-05-07 13:12:25 +05:30
< p align = "center" >
2020-10-12 17:28:36 +05:30
< a href = "https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=RMLTQ76JSXJ4Q" >< img src = "https://img.shields.io/badge/donate- @PayPal -1eb0fc.svg" alt = "Donate via PayPal!" /></ a >
2017-03-13 10:01:35 +05:30
< / p >
2017-08-18 17:58:26 +05:30
### Table of Contents
- [Features ](#features )
- [Installation ](#installation )
- [Dependencies ](#dependencies )
- [From a package manager ](#from-a-package-manager )
- [Release packages ](#release-packages )
- [From source ](#from-source )
- [Running standalone ](#running-standalone )
- [Shell completion ](#shell-completion )
- [Usage ](#usage )
2019-01-10 21:13:20 -06:00
- [Command-line options ](#command-line-options )
2017-08-25 03:16:54 +05:30
- [Colors ](#colors )
2018-09-17 04:55:47 +05:30
- [Quickstart ](#quickstart )
2017-08-18 17:58:26 +05:30
- [Examples ](#examples )
2019-03-20 19:10:10 +05:30
- [Automation ](#automation )
2017-09-19 05:55:22 +05:30
- [Troubleshooting ](#troubleshooting )
- [Editor integration ](#editor-integration )
2017-08-18 17:58:26 +05:30
- [Collaborators ](#collaborators )
2018-07-10 09:49:05 +05:30
- [Contributions ](#contributions )
2017-08-18 17:58:26 +05:30
- [Related projects ](#related-projects )
- [In the Press ](#in-the-press )
2017-03-29 12:37:43 +05:30
### Features
2016-09-05 21:57:11 +05:30
2018-08-05 16:37:16 +05:30
- Store bookmarks with auto-fetched title, tags and description
2018-07-10 09:49:05 +05:30
- Auto-import from Firefox, Google Chrome and Chromium
- Open bookmarks and search results in browser
- Shorten, expand URLs, browse cached page from Wayback Machine
2017-08-15 10:06:29 +05:30
- Text editor integration
2018-07-10 09:49:05 +05:30
- Lightweight, clean interface, custom colors
- Powerful search options (regex, substring...)
2017-08-15 10:06:29 +05:30
- Continuous search with on the fly mode switch
2018-07-10 09:49:05 +05:30
- Portable, merge-able database to sync between systems
2018-05-11 06:46:47 +05:30
- Import/export bookmarks from/to HTML, Markdown or Orgfile
2017-08-13 14:33:06 +05:30
- Smart tag management using redirection (>>, >, << )
2018-07-10 09:49:05 +05:30
- Multithreaded full DB refresh, manual encryption support
2017-08-13 09:56:39 +05:30
- Shell completion scripts, man page with handy examples
2019-11-30 04:56:01 +05:30
- Privacy-aware (no unconfirmed user data collection)
2016-09-05 21:57:11 +05:30
2017-03-29 12:37:43 +05:30
### Installation
2016-05-23 14:32:46 +05:30
2017-03-29 12:37:43 +05:30
#### Dependencies
2016-05-23 14:32:46 +05:30
2017-03-13 10:01:35 +05:30
| Feature | Dependency |
| --- | --- |
2020-10-10 13:57:29 +05:30
| Scripting language | Python 3.6+ |
2018-08-06 06:34:58 +05:30
| HTTPS | certifi, urllib3 |
2017-03-13 10:01:35 +05:30
| Encryption | cryptography |
2018-08-29 08:13:17 +05:30
| HTML | beautifulsoup4, html5lib |
2015-11-09 03:34:49 +05:30
2020-01-08 08:37:17 +05:30
To copy url to clipboard at the prompt `buku` uses `xsel` (or `xclip` ) on Linux, `pbcopy` (default installed) on OS X, `clip` (default installed) on Windows, `termux-clipboard` on Termux (terminal emulation for Android). If X11 is missing, GNU Screen or tmux copy-paste buffers are recognized.
2018-02-11 05:21:36 +05:30
2017-08-14 05:24:16 +05:30
#### From a package manager
2017-03-17 08:35:27 +05:30
2020-02-26 08:20:45 +05:30
To install buku with all its dependencies from PyPI, run:
# pip3 install buku
You can also install `buku` from your package manager. If the version available is dated try an alternative installation method.
2019-12-21 07:09:01 +05:30
< details > < summary > Packaging status (expand)< / summary >
< p >
< br >
< a href = "https://repology.org/project/buku/versions" > < img src = "https://repology.org/badge/vertical-allrepos/buku.svg" alt = "Packaging status" > < / a >
< / p >
Unlisted packagers:
< p >
< br >
● < a href = "https://pypi.org/project/buku/" > PyPI< / a > (< code > pip3 install buku< / code > )< br >
● Termux (< code > pip3 install buku< / code > )< br >
< / p >
< / details >
2017-08-14 05:24:16 +05:30
#### Release packages
2020-01-08 08:37:17 +05:30
Auto-generated packages (with only the cli component) for Arch Linux, CentOS, Debian, Fedora, openSUSE Leap and Ubuntu are available with the [latest stable release ](https://github.com/jarun/buku/releases/latest ).
2017-11-25 05:07:04 +05:30
NOTE: CentOS may not have the python3-beautifulsoup4 package in the repos. Install it using pip3.
2017-08-14 05:24:16 +05:30
#### From source
2016-02-28 19:41:27 +05:30
2020-01-08 08:37:17 +05:30
If you have git installed, clone this repository. Otherwise download the [latest stable release ](https://github.com/jarun/buku/releases/latest ) or [development version ](https://github.com/jarun/buku/archive/master.zip ) (*risky*).
2016-02-28 19:41:27 +05:30
2020-02-26 08:20:45 +05:30
Install the dependencies. For example, on Ubuntu:
$ apt-get install ca-certificates python3-urllib3 python3-cryptography python3-bs4
2019-05-26 21:08:47 +05:30
Install the cli component to default location (`/usr/local` ):
2016-02-28 19:41:27 +05:30
2016-04-10 18:11:00 +05:30
$ sudo make install
To remove, run:
2015-11-09 03:34:49 +05:30
2016-02-28 19:41:27 +05:30
$ sudo make uninstall
2015-12-19 23:45:22 +05:30
2017-08-14 05:24:16 +05:30
`PREFIX` is supported, in case you want to install to a different location.
#### Running standalone
2016-05-23 14:32:46 +05:30
2016-02-28 19:41:27 +05:30
`buku` is a standalone utility. From the containing directory, run:
2018-11-12 00:15:18 +05:30
$ chmod +x buku
$ ./buku
2016-05-23 14:32:46 +05:30
2017-03-29 12:37:43 +05:30
### Shell completion
2016-09-11 20:54:33 +05:30
2020-01-08 08:37:17 +05:30
Shell completion scripts for Bash, Fish and Zsh can be found in respective subdirectories of [auto-completion/ ](https://github.com/jarun/buku/blob/master/auto-completion ). Please refer to your shell's manual for installation instructions.
2016-09-11 20:54:33 +05:30
2017-03-29 12:37:43 +05:30
### Usage
2016-05-23 14:32:46 +05:30
2019-01-10 21:13:20 -06:00
#### Command-line options
2017-08-25 03:16:54 +05:30
2017-01-04 21:47:02 +05:30
```
usage: buku [OPTIONS] [KEYWORD [KEYWORD ...]]
2016-03-21 01:23:57 +05:30
2018-05-11 08:00:40 +05:30
Bookmark manager like a text-based mini-web.
2016-02-28 19:41:27 +05:30
2017-01-29 19:19:47 +05:30
POSITIONAL ARGUMENTS:
KEYWORD search keywords
2017-01-04 21:47:02 +05:30
GENERAL OPTIONS:
2016-11-15 00:07:22 +05:30
-a, --add URL [tag, ...]
2016-05-19 08:54:46 +05:30
bookmark URL with comma-separated tags
2017-02-11 11:33:29 +05:30
-u, --update [...] update fields of an existing bookmark
2016-10-11 13:09:58 +05:30
accepts indices and ranges
2019-02-02 11:18:26 +05:30
refresh title and desc if no edit options
2017-02-11 11:33:29 +05:30
if no arguments:
- update results when used with search
2019-02-02 09:52:59 +05:30
- otherwise refresh all titles and desc
2017-02-11 11:33:29 +05:30
-w, --write [editor|index]
open editor to edit a fresh bookmark
2017-10-09 01:21:13 +05:30
edit last bookmark, if index=-1
to specify index, EDITOR must be set
2017-02-11 11:33:29 +05:30
-d, --delete [...] remove bookmarks from DB
accepts indices or a single range
if no arguments:
- delete results when used with search
- otherwise delete all bookmarks
2016-05-31 11:23:01 +05:30
-h, --help show this information and exit
2017-02-11 11:33:29 +05:30
-v, --version show the program version and exit
2016-05-21 22:59:41 +05:30
2017-01-04 21:47:02 +05:30
EDIT OPTIONS:
2017-02-11 11:33:29 +05:30
--url keyword bookmark link
--tag [+|-] [...] comma-separated tags
clear bookmark tagset, if no arguments
'+' appends to, '-' removes from tagset
2017-03-16 23:45:37 +05:30
--title [...] bookmark title; if no arguments:
2016-05-20 23:56:01 +05:30
-a: do not set title, -u: clear title
2017-03-17 08:35:27 +05:30
-c, --comment [...] notes or description of the bookmark
2017-02-11 11:33:29 +05:30
clears description, if no arguments
2018-08-05 16:37:16 +05:30
--immutable N disable web-fetch during auto-refresh
2016-11-06 04:02:03 +05:30
N=0: mutable (default), N=1: immutable
2016-04-29 23:39:39 +05:30
2017-01-04 21:47:02 +05:30
SEARCH OPTIONS:
2018-03-27 04:38:24 +05:30
-s, --sany [...] find records with ANY matching keyword
2017-01-29 19:19:47 +05:30
this is the default search option
2018-03-27 04:38:24 +05:30
-S, --sall [...] find records matching ALL the keywords
2016-11-06 20:11:45 +05:30
special keywords -
2016-11-12 22:36:31 +05:30
"blank": entries with empty title/tag
"immutable": entries with locked title
2016-11-25 23:40:25 +05:30
--deep match substrings ('pen' matches 'opens')
2018-03-27 04:38:24 +05:30
-r, --sreg expr run a regex search
2017-08-14 17:07:01 -04:00
-t, --stag [tag [,|+] ...] [- tag, ...]
search bookmarks by tags
use ',' to find entries matching ANY tag
use '+' to find entries matching ALL tags
2017-09-17 11:53:55 +05:30
excludes entries with tags after ' - '
2017-01-29 19:19:47 +05:30
list all tags, if no search keywords
2018-03-26 09:03:46 +05:30
-x, --exclude [...] omit records matching specified keywords
2017-08-15 10:06:29 +05:30
2017-01-04 21:47:02 +05:30
ENCRYPTION OPTIONS:
2017-09-17 11:53:55 +05:30
-l, --lock [N] encrypt DB in N (default 8) # iterations
-k, --unlock [N] decrypt DB in N (default 8) # iterations
2016-04-29 23:39:39 +05:30
2017-01-04 21:47:02 +05:30
POWER TOYS:
2017-11-07 06:56:56 +05:30
--ai auto-import from Firefox/Chrome/Chromium
2019-01-10 21:13:20 -06:00
-e, --export file export bookmarks to Firefox format HTML
export Markdown, if file ends with '.md'
2020-01-31 03:11:54 +05:30
format: [title ](url ) <!-- TAGS -->
2019-01-10 21:13:20 -06:00
export Orgfile, if file ends with '.org'
2020-01-31 03:11:54 +05:30
format: *[[url][title]] :tags:
2017-09-17 11:53:18 +05:30
export buku DB, if file ends with '.db'
2018-08-28 05:59:32 +05:30
combines with search results, if opted
2019-01-15 05:24:58 +05:30
-i, --import file import bookmarks based on file extension
supports 'html', 'json', 'md', 'org', 'db'
2017-02-11 11:33:29 +05:30
-p, --print [...] show record details by indices, ranges
print all bookmarks, if no arguments
2017-03-19 00:45:26 +05:30
-n shows the last n results (like tail)
2019-01-10 21:13:20 -06:00
-f, --format N limit fields in -p or JSON search output
2019-04-30 07:47:42 +05:30
N=1: URL; N=2: URL, tag; N=3: title;
N=4: URL, title, tag; N=5: title, tag;
N0 (10, 20, 30, 40, 50) omits DB index
2020-04-20 18:15:04 +02:00
-j, --json [file] JSON formatted output for -p and search.
2020-10-13 15:02:38 +05:30
prints to stdout if argument missing.
2020-04-20 18:15:04 +02:00
otherwise writes to given file
2017-08-23 10:13:55 +05:30
--colors COLORS set output colors in five-letter string
2017-02-10 19:25:05 +05:30
--nc disable color output
2018-06-17 08:05:32 +05:30
-n, --count N show N results per page (default 10)
2020-07-23 08:23:55 +05:30
--np do not show the subprompt, run and exit
2017-02-11 11:33:29 +05:30
-o, --open [...] browse bookmarks by indices and ranges
open a random bookmark, if no arguments
--oa browse all search results immediately
2017-03-17 08:35:27 +05:30
--replace old new replace old tag with new tag everywhere
delete old tag, if new tag not specified
2017-02-11 11:33:29 +05:30
--shorten index|URL fetch shortened url from tny.im service
--expand index|URL expand a tny.im shortened url
2018-05-25 22:09:12 +05:30
--cached index|URL browse a cached page from Wayback Machine
2017-08-01 21:07:03 +05:30
--suggest show similar tags when adding bookmarks
2020-07-23 08:23:55 +05:30
--tacit reduce verbosity, skip some confirmations
2016-12-03 18:50:53 +05:30
--threads N max network connections in full refresh
2017-01-29 19:19:47 +05:30
default N=4, min N=1, max N=10
2017-02-10 20:34:24 +05:30
-V check latest upstream version available
2020-10-13 14:56:49 +05:30
-g, --debug show debug information and verbose logs
2016-04-29 23:39:39 +05:30
2017-01-04 21:47:02 +05:30
SYMBOLS:
2017-04-09 01:49:25 +05:30
> url
2016-07-03 15:36:50 +05:30
+ comment
# tags
2017-07-25 09:28:32 +05:30
2017-08-13 14:33:06 +05:30
PROMPT KEYS:
2017-07-25 09:28:32 +05:30
1-N browse search result indices and/or ranges
2018-11-01 22:09:52 +05:30
O [id|range [...]] open search results/indices in GUI browser
toggle try GUI browser if no arguments
2017-07-25 09:28:32 +05:30
a open all results in browser
s keyword [...] search for records with ANY keyword
S keyword [...] search for records with ALL keywords
d match substrings ('pen' matches 'opened')
r expression run a regex search
2018-09-02 11:35:40 +05:30
t [tag, ...] search by tags; show taglist, if no args
2018-09-02 03:07:54 +05:30
g taglist id|range [...] [>>|>|< < ] [record id|range ...]
append, set, remove (all or specific) tags
search by taglist id(s) if records are omitted
2018-06-17 08:05:32 +05:30
n show next page of search results
2017-08-13 14:33:06 +05:30
o id|range [...] browse bookmarks by indices and/or ranges
p id|range [...] print bookmarks by indices and/or ranges
w [editor|id] edit and add or update a bookmark
2018-02-11 05:12:21 +05:30
c id copy url at search result index to clipboard
2017-07-25 09:28:32 +05:30
? show this help
q, ^D, double Enter exit buku
2017-01-04 21:47:02 +05:30
```
2016-07-03 15:36:50 +05:30
2017-08-25 03:16:54 +05:30
#### Colors
2020-01-08 08:37:17 +05:30
`buku` supports custom colors. Visit the wiki page on how to [customize colors ](https://github.com/jarun/buku/wiki/Customize-colors ) for more details.
2017-08-25 03:00:45 +05:30
2018-09-17 04:55:47 +05:30
### Quickstart
1. Export `VISUAL` or `EDITOR` to point to your favourite editor. Note that `VISUAL` takes precedence over `EDITOR` .
2. Create a sweeter shortcut with some convenience.
alias b='buku --suggest'
2019-03-20 19:18:43 +05:30
3. Auto-import bookmarks from your browser(s). Please quit the relevant browsers beforehand to ensure the databases are not locked.
2018-09-17 04:55:47 +05:30
b --ai
4. Manually add a bookmark (for hands-on).
b -w
5. List your bookmarks with DB index.
b -p
2020-01-08 08:37:17 +05:30
6. For GUI and browser integration (or to sync bookmarks with your favourite bookmark management service) refer to the wiki page on [System integration ](https://github.com/jarun/buku/wiki/System-integration ).
2020-12-08 22:24:57 +05:30
7. Handy (bash/zsh) commands to fuzzy search with fzf and open the selection in Firefox:
2020-02-09 05:12:02 +05:30
2020-10-11 08:34:08 +05:30
firefox $(buku -p -f 10 | fzf)
2020-12-07 20:59:54 +05:30
firefox $(buku -p -f 40 | fzf | cut -f1)
2020-12-08 22:24:57 +05:30
POSIX script to show a preview of the bookmark as well:
2020-12-07 20:59:54 +05:30
```sh
#!/usr/bin/env sh
2020-12-08 22:24:57 +05:30
url=$(buku -p -f4 | fzf -m --reverse --preview "buku -p {1}" --preview-window=wrap | cut -f2)
2020-12-07 20:59:54 +05:30
if [ -n "$url" ]; then
2020-12-08 22:24:57 +05:30
echo "$url" | xargs firefox
2020-12-07 20:59:54 +05:30
fi
```
2018-09-17 04:55:47 +05:30
2017-03-29 12:37:43 +05:30
### Examples
2016-05-23 14:32:46 +05:30
2017-02-05 22:35:45 +05:30
1. **Edit and add** a bookmark from editor:
2017-10-02 07:41:16 +05:30
$ buku -w
$ buku -w 'gedit -w'
$ buku -w 'macvim -f' -a https://ddg.gg search engine, privacy
2017-09-19 05:55:22 +05:30
The first command picks editor from the environment variable `EDITOR` . The second command opens gedit in blocking mode. The third command opens macvim with option -f and the URL and tags populated in template.
2017-02-05 22:35:45 +05:30
2. **Add** a bookmark with **tags** `search engine` and `privacy` , **comment** `Search engine with perks` , **fetch page title** from the web:
2017-10-02 07:41:16 +05:30
$ buku -a https://ddg.gg search engine, privacy -c Search engine with perks
336. DuckDuckGo
> https://ddg.gg
+ Alternative search engine with perks
# privacy,search engine
2017-04-09 01:49:25 +05:30
where, >: url, +: comment, #: tags
2017-02-05 22:35:45 +05:30
3. **Add** a bookmark with tags `search engine` & `privacy` and **immutable custom title** `DDG` :
2016-02-28 20:02:10 +05:30
2017-10-02 07:41:16 +05:30
$ buku -a https://ddg.gg search engine, privacy --title 'DDG' --immutable 1
336. DDG (L)
> https://ddg.gg
# privacy,search engine
2017-03-17 08:35:27 +05:30
Note that URL must precede tags.
2017-02-05 22:35:45 +05:30
4. **Add** a bookmark **without a title** (works for update too):
2016-02-28 20:02:10 +05:30
2017-10-02 07:41:16 +05:30
$ buku -a https://ddg.gg search engine, privacy --title
2017-02-07 23:33:51 +05:30
5. **Edit and update** a bookmark from editor:
2017-10-02 07:41:16 +05:30
$ buku -w 15012014
2017-03-17 08:35:27 +05:30
This will open the existing bookmark's details in the editor for modifications. Environment variable `EDITOR` must be set.
2017-02-07 23:33:51 +05:30
6. **Update** existing bookmark at index 15012014 with new URL, tags and comments, fetch title from the web:
2016-05-20 23:56:01 +05:30
2017-10-02 07:41:16 +05:30
$ buku -u 15012014 --url http://ddg.gg/ --tag web search, utilities -c Private search engine
2017-02-07 23:33:51 +05:30
7. **Fetch and update only title** for bookmark at 15012014:
2016-05-20 23:56:01 +05:30
2017-10-02 07:41:16 +05:30
$ buku -u 15012014
2017-02-07 23:33:51 +05:30
8. **Update only comment** for bookmark at 15012014:
2016-05-20 23:56:01 +05:30
2017-10-02 07:41:16 +05:30
$ buku -u 15012014 -c this is a new comment
2017-03-17 08:35:27 +05:30
Applies to --url, --title and --tag too.
2019-01-10 21:13:20 -06:00
9. **Export** bookmarks tagged `tag 1` or `tag 2` to HTML, Markdown, Orgfile or a new database:
2016-09-20 23:32:04 +05:30
2018-08-28 05:59:32 +05:30
$ buku -e bookmarks.html --stag tag 1, tag 2
$ buku -e bookmarks.md --stag tag 1, tag 2
$ buku -e bookmarks.org --stag tag 1, tag 2
$ buku -e bookmarks.db --stag tag 1, tag 2
All bookmarks are exported if search is not opted.
2019-01-10 21:13:20 -06:00
10. **Import** bookmarks from HTML, Markdown or Orgfile:
2016-05-23 05:06:41 +05:30
$ buku -i bookmarks.html
2017-02-10 22:09:02 +05:30
$ buku -i bookmarks.md
2018-05-11 06:46:47 +05:30
$ buku -i bookmarks.org
2017-09-17 18:06:31 +05:30
$ buku -i bookmarks.db
2017-02-04 20:15:33 +05:30
11. **Delete only comment** for bookmark at 15012014:
2016-02-28 20:02:10 +05:30
2016-05-20 23:56:01 +05:30
$ buku -u 15012014 -c
2017-03-17 08:35:27 +05:30
Applies to --title and --tag too. URL cannot be deleted without deleting the bookmark.
2017-02-04 20:15:33 +05:30
12. **Update** or refresh **full DB** with page titles from the web:
2016-02-28 20:02:10 +05:30
2016-05-01 10:03:21 +05:30
$ buku -u
2016-11-08 23:02:45 +05:30
$ buku -u --tacit (show only failures and exceptions)
2019-02-02 09:52:59 +05:30
This operation can update the title or description fields of non-immutable bookmarks by parsing the fetched page. Fields are updated only if the fetched fields are non-empty. Tags remain untouched.
2017-02-04 20:15:33 +05:30
13. **Delete** bookmark at index 15012014:
2016-02-28 20:02:10 +05:30
$ buku -d 15012014
2016-03-20 11:23:59 +05:30
Index 15012020 moved to 15012014
2020-07-23 08:23:55 +05:30
The last index is moved to the deleted index to keep the DB compact. Add `--tacit` to delete without confirmation.
2017-02-04 20:15:33 +05:30
14. **Delete all** bookmarks:
2016-02-28 20:02:10 +05:30
2016-05-01 10:03:21 +05:30
$ buku -d
2017-02-04 20:15:33 +05:30
15. **Delete** a **range or list** of bookmarks:
2016-06-17 02:38:38 +05:30
2016-10-22 12:12:11 +05:30
$ buku -d 100-200
$ buku -d 100 15 200
2017-02-04 20:15:33 +05:30
16. **Search** bookmarks for **ANY** of the keywords `kernel` and `debugging` in URL, title or tags:
2016-02-28 20:02:10 +05:30
2017-02-20 19:35:55 +05:30
$ buku kernel debugging
2016-02-28 20:02:10 +05:30
$ buku -s kernel debugging
2017-02-04 20:15:33 +05:30
17. **Search** bookmarks with **ALL** the keywords `kernel` and `debugging` in URL, title or tags:
2016-02-28 20:02:10 +05:30
$ buku -S kernel debugging
2017-02-04 20:15:33 +05:30
18. **Search** bookmarks **tagged** `general kernel concepts` :
2016-04-19 23:00:06 +05:30
2016-11-07 23:05:02 +05:30
$ buku --stag general kernel concepts
2017-08-14 17:07:01 -04:00
19. **Search** for bookmarks matching **ANY** of the tags `kernel` , `debugging` , `general kernel concepts` :
$ buku --stag kernel, debugging, general kernel concepts
20. **Search** for bookmarks matching **ALL** of the tags `kernel` , `debugging` , `general kernel concepts` :
$ buku --stag kernel + debugging + general kernel concepts
2018-03-26 09:03:46 +05:30
21. **Search** for bookmarks matching any of the keywords `hello` or `world` , excluding the keywords `real` and `life` , matching both the tags `kernel` and `debugging` , but **excluding** the tags `general kernel concepts` and `books` :
2017-08-14 17:07:01 -04:00
2018-03-26 09:03:46 +05:30
$ buku hello world --exclude real life --stag 'kernel + debugging - general kernel concepts, books'
2017-08-14 17:07:01 -04:00
22. List **all unique tags** alphabetically:
2016-05-01 14:13:26 +05:30
2016-11-07 23:05:02 +05:30
$ buku --stag
2017-08-14 17:07:01 -04:00
23. Run a **search and update** the results:
2017-01-09 09:52:22 +05:30
2017-03-17 08:35:27 +05:30
$ buku -s kernel debugging -u --tag + linux kernel
2017-08-14 17:07:01 -04:00
24. Run a **search and delete** the results:
2016-11-26 19:58:22 +05:30
$ buku -s kernel debugging -d
2017-08-14 17:07:01 -04:00
25. **Encrypt or decrypt** DB with **custom number of iterations** (15) to generate key:
2016-02-28 20:02:10 +05:30
2016-05-01 10:03:21 +05:30
$ buku -l 15
$ buku -k 15
2017-03-17 08:35:27 +05:30
The same number of iterations must be specified for one lock & unlock instance. Default is 8, if omitted.
2017-08-14 17:07:01 -04:00
26. **Show details** of bookmarks at index 15012014 and ranges 20-30, 40-50:
2016-05-01 14:13:26 +05:30
2016-10-11 22:15:07 +05:30
$ buku -p 20-30 15012014 40-50
2017-08-14 17:07:01 -04:00
27. Show details of the **last 10 bookmarks** :
2017-03-19 00:45:26 +05:30
$ buku -p -10
2017-08-14 17:07:01 -04:00
28. **Show all** bookmarks with real index from database:
2016-05-01 14:13:26 +05:30
$ buku -p
2016-05-03 23:22:36 +05:30
$ buku -p | more
2017-08-14 17:07:01 -04:00
29. **Replace tag** 'old tag' with 'new tag':
2016-05-01 14:13:26 +05:30
2017-03-17 08:35:27 +05:30
$ buku --replace 'old tag' 'new tag'
2017-08-14 17:07:01 -04:00
30. **Delete tag** 'old tag' from DB:
2016-05-01 14:13:26 +05:30
2017-03-17 00:07:51 +05:30
$ buku --replace 'old tag'
2017-08-14 17:07:01 -04:00
31. **Append (or delete) tags** 'tag 1', 'tag 2' to (or from) existing tags of bookmark at index 15012014:
2016-06-12 16:18:10 +05:30
$ buku -u 15012014 --tag + tag 1, tag 2
2016-07-11 22:48:40 +05:30
$ buku -u 15012014 --tag - tag 1, tag 2
2017-08-14 17:07:01 -04:00
32. **Open URL** at index 15012014 in browser:
2016-05-01 14:13:26 +05:30
$ buku -o 15012014
2017-08-14 17:07:01 -04:00
33. List bookmarks with **no title or tags** for bookkeeping:
2016-03-29 18:13:43 +05:30
2016-05-01 19:14:17 +05:30
$ buku -S blank
2017-08-14 17:07:01 -04:00
34. List bookmarks with **immutable title** :
2016-11-06 20:11:45 +05:30
$ buku -S immutable
2017-08-14 17:07:01 -04:00
35. **Shorten URL** www.google.com and the URL at index 20:
2016-11-12 21:17:36 +05:30
$ buku --shorten www.google.com
$ buku --shorten 20
2017-08-14 17:07:01 -04:00
36. **Append, remove tags at prompt** (taglist index to the left, bookmark index to the right):
2017-04-07 00:49:08 +05:30
// append tags at taglist indices 4 and 6-9 to existing tags in bookmarks at indices 5 and 2-3
buku (? for help) g 4 9-6 >> 5 3-2
// set tags at taglist indices 4 and 6-9 as tags in bookmarks at indices 5 and 2-3
buku (? for help) g 4 9-6 > 5 3-2
// remove all tags from bookmarks at indices 5 and 2-3
buku (? for help) g > 5 3-2
// remove tags at taglist indices 4 and 6-9 from tags in bookmarks at indices 5 and 2-3
buku (? for help) g 4 9-6 < < 5 3-2
2019-05-04 21:39:05 +05:30
37. List bookmarks with **colored output** :
2017-08-23 00:09:43 +02:00
2017-08-25 02:29:39 +05:30
$ buku --colors oKlxm -p
2019-05-04 21:39:05 +05:30
38. More **help** :
2016-02-28 20:02:10 +05:30
2016-11-26 19:58:22 +05:30
$ buku -h
2016-05-23 11:51:29 +05:30
$ man buku
2015-11-09 03:34:49 +05:30
2019-03-20 19:10:10 +05:30
### Automation
2020-01-08 08:37:17 +05:30
Interactive workflows can be automated using expect. Issue [#368 ](https://github.com/jarun/buku/issues/368 ) has a working example on automating auto-import.
2019-03-20 19:10:10 +05:30
2017-09-19 05:55:22 +05:30
### Troubleshooting
#### Editor integration
2020-01-08 08:37:17 +05:30
You may encounter issues with GUI editors which maintain only one instance by default and return immediately from other instances. Use the appropriate editor option to block the caller when a new document is opened. See issue [#210 ](https://github.com/jarun/buku/issues/210 ) for gedit.
2017-09-19 05:55:22 +05:30
2017-03-29 12:37:43 +05:30
### Collaborators
2016-05-31 21:51:10 +05:30
2017-03-29 12:37:43 +05:30
- [Arun Prakash Jana ](https://github.com/jarun )
- [Rachmadani Haryono ](https://github.com/rachmadaniHaryono )
2017-08-13 03:46:34 +05:30
- [Johnathan Jenkins ](https://github.com/shaggytwodope )
- [SZ Lin ](https://github.com/szlin )
2016-05-23 14:32:46 +05:30
2020-12-29 02:17:35 +05:30
Copyright © 2015-2021 [Arun Prakash Jana ](mailto:engineerarun@gmail.com )
2017-03-29 12:37:43 +05:30
< br >
2020-01-08 08:37:17 +05:30
< p > < a href = "https://gitter.im/jarun/buku" > < img src = "https://img.shields.io/gitter/room/jarun/buku.svg?maxAge=2592000" alt = "gitter chat" / > < / a > < / p >
2017-08-15 10:06:29 +05:30
2018-07-10 09:49:05 +05:30
### Contributions
2020-11-26 00:10:58 +05:30
Missing a feature? There's a rolling [ToDo List ](https://github.com/jarun/buku/issues/484 ) with identified tasks. Contributions are welcome! Please follow the [PR guidelines ](https://github.com/jarun/buku/wiki/PR-guidelines ).
2018-07-10 09:49:05 +05:30
2017-08-15 10:06:29 +05:30
### Related projects
- [bukubrow ](https://github.com/SamHH/bukubrow ), WebExtension for browser integration
2019-01-10 21:13:20 -06:00
- [oil ](https://github.com/AndreiUlmeyda/oil ), search-as-you-type cli front-end
- [buku_run ](https://github.com/carnager/buku_run ), rofi front-end
2020-01-08 08:37:17 +05:30
- [pinku ](https://github.com/mosegontar/pinku ), a Pinboard-to-buku import utility
2018-08-31 14:01:15 +05:30
- [buku-dmenu ](https://gitlab.com/benoliver999/buku-dmenu ), a simple bash dmenu wrapper
2020-01-08 08:37:17 +05:30
- [poku ](https://github.com/shanedabes/poku ), sync between Pocket and buku
- [Ebuku ](https://github.com/flexibeast/ebuku ), Emacs interface to buku
2017-08-15 10:06:29 +05:30
2017-09-11 03:27:45 +05:30
< a href = "http://buku.readthedocs.io/en/stable/?badge=stable" > < img src = "https://img.shields.io/badge/docs-stable-brightgreen.svg?maxAge=2592000" alt = "Stable Docs" / > < / a >
2020-12-05 22:44:34 +05:30
### Videos
- [Buku: Take Your Bookmarks Everywhere You Go ](https://www.youtube.com/embed/9HzEHrUBQXE )
- [Buku is a great open-source bookmark manager ](https://www.youtube.com/embed/7VxgKMWm-J8 )
2017-08-15 10:06:29 +05:30
### In the Press
- [2daygeek ](http://www.2daygeek.com/buku-command-line-bookmark-manager-linux/ )
2020-01-30 06:03:07 +05:30
- [Hacker Milk ](https://hackermilk.blogspot.com/2020/01/how-to-manage-your-browsers-bookmarks.html )
2017-10-10 18:24:25 +05:30
- [It's F.O.S.S. ](https://itsfoss.com/buku-command-line-bookmark-manager-linux/ )
2017-08-15 10:06:29 +05:30
- [LinOxide ](https://linoxide.com/linux-how-to/buku-browser-bookmarks-linux/ )
2017-10-10 18:24:25 +05:30
- [LinuxUser Magazine 01/2017 Issue ](http://www.linux-community.de/LU/2017/01/Das-Beste-aus-zwei-Welten )
- [Make Tech Easier ](https://www.maketecheasier.com/manage-browser-bookmarks-ubuntu-command-line/ )
- [One Thing Well ](http://onethingwell.org/post/144952807044/buku )
2018-08-26 12:31:57 +05:30
- [Open Source For You ](https://opensourceforu.com/2018/05/buku-a-bookmark-manager-in-the-command-line/ )
2017-10-10 18:24:25 +05:30
- [ulno.net ](https://ulno.net/blog/2017-07-19/of-bookmarks-tags-and-browsers/ )