diff --git a/plugins/README.md b/plugins/README.md
index 1300233b..304888b3 100644
--- a/plugins/README.md
+++ b/plugins/README.md
@@ -15,6 +15,7 @@ The currently available plugins are listed below.
| dragdrop | sh | [dragon](https://github.com/mwh/dragon) | Drag/drop files from/into nnn |
| exetoggle | sh | chmod | Toggle executable status of hovered file |
| fzcd | sh | fzy/fzf
(optional fd) | Change to the directory of a fuzzy-selected file/dir |
+| fzhist | sh | fzy | Fuzzy-select a cmd from history, edit in $EDITOR and run |
| fzopen | sh | fzy, xdg-open | Fuzzy find a file in dir subtree and edit or xdg-open |
| getplugs | sh | curl | Update plugins |
| gutenread | sh | curl, unzip, w3m
[epr](https://github.com/wustho/epr) (optional)| Browse, download, read from Project Gutenberg |
diff --git a/plugins/fzhist b/plugins/fzhist
new file mode 100755
index 00000000..bad4e2de
--- /dev/null
+++ b/plugins/fzhist
@@ -0,0 +1,31 @@
+#!/usr/bin/env sh
+
+# Description: Fuzzy find a command from history, edit in $EDITOR and run as a command
+# Currently supports only bash and fish history
+#
+# Shell: POSIX compliant
+# Author: Arun Prakash Jana
+
+shellname="$(basename "$SHELL")"
+
+if [ "$shellname" = "bash" ]; then
+ hist_file="$HOME/.bash_history"
+ entry="$(cat "$hist_file" | fzy)"
+elif [ "$shellname" = "fish" ]; then
+ hist_file="$HOME/.config/fish/fish_history"
+ entry="$(cat "$hist_file" | grep "\- cmd: " | cut -c 8- | fzy)"
+fi
+
+if ! [ -z "$entry" ]; then
+ tmpfile=$(mktemp)
+ echo "$entry" >> $tmpfile
+ $EDITOR $tmpfile
+
+ cmd="$(cat $tmpfile)"
+
+ if ! [ -z "$cmd" ]; then
+ $SHELL -c "$cmd"
+ fi
+
+ rm $tmpfile
+fi