What is "-bash: !": event not found"
Solution 1
You can turn off history substitution using set +H
.
Solution 2
!
is a special character to bash, it is used to refer to previous commands; eg,
!rm
will recall and execute the last command that began with the string "rm", and
!rm:p
will recall but not execute the last command that began with the string "rm". bash is interpreting the exclamation mark in echo "reboot your instance!"
as "substitute here the last command that began with the character(s) immediately following the exclamation mark", and grumbles at you that it cannot find an event (command) in your history that began with a single double-quote.
Try
echo reboot your instance\!
to protect (escape) the exclamation mark from bash.
Solution 3
To solve your original problem, try using single quotes, rather than double quotes. With the latter, bash will attempt to expand certain characters before passing the result on to the command (echo in this case). With single quotes, bash passes the entire string, unchanged.
!
is used in commands to refer to the command line history. See: http://tldp.org/LDP/abs/html/abs-guide.html#HISTCOMMANDS for a full set. With the above example, bash is trying to expand !"
as a reference to an event before echo gets a look in, hence the error.
Note that in scripts, all of the history commands are disabled, as they only make sense in an interactive shell.
The only one I use on a regular basis, is !$
. It expands to the last argument of the previous command. It's a useful shorthand in places.
Solution 4
Just put a space between !
and "
than it'll work.
Solution 5
Yes, ! is a special character to bash, it is used to refer to previous commands.
Few of the ways you can handle the situation
The following will output the string as it is
echo 'Reboot your instance!'
The following will execute the command and concatenate the string
echo 'escaping #'" adding `which python` to the string"
echo '#!'`which python`
Related videos on Youtube
Comments
-
Maxim Veksler over 1 year
Try executing the following under a bash shell
echo "Reboot your instance!"
On my installation:
root@domU-12-31-39-04-11-83:/usr/local/bin# bash --version GNU bash, version 4.1.5(1)-release (i686-pc-linux-gnu) Copyright (C) 2009 Free Software Foundation, Inc. License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html> This is free software; you are free to change and redistribute it. There is NO WARRANTY, to the extent permitted by law. root@domU-12-31-39-04-11-83:/usr/local/bin# uname -a Linux domU-12-31-39-04-11-83 2.6.35-22-virtual #35-Ubuntu SMP Sat Oct 16 23:57:40 UTC 2010 i686 GNU/Linux root@domU-12-31-39-04-11-83:/usr/local/bin# echo "Reboot your instance!" -bash: !": event not found
Can anyone please explain what is "bash events?" I've never heard this concept before. Also, how should I output "!" at the end of the sentence?
-
jgoldschrafe over 13 years
!!
to fill in the complete last command entered is remarkably useful; particularly,sudo !!
orpfexec !!
-
Maxim Veksler over 13 yearsYes, but should happen if I want to use echo -e "some text $ENV_VAL some more text\nReboot now!" ?
-
MadHatter over 13 yearsWrite two echo statements; you get the linefeed for free.
-
LeartS about 10 yearsI also find sudo and pfexec to be nice utilities, but no need to be so enthusiastic.
-
Icebreaker over 9 yearsCould you please add an explanation as to why your solution works?
-
mmey over 9 yearsThis works because Bash only treats ! as a special character if it's directly followed by a non-whitespace character. However, it will also add an extra blank to your output, so that might not always be desired...
-
mmey over 9 yearsSimple solution is to use single quotes and double quotes at once: echo -e "Text\nReeboot"'!'
-
MadHatter over 9 yearsI'm not sure that's simpler, but it will work, yes.
-
Hafizur Rahman over 9 yearsThis sucks. If I don't escape the exclamation mark, bash throws a fit. If I do escape it, the backslash is included in the final string. Why do you do this, Bash!! (pastebin.com/g4PYv56A)
-
MadHatter over 9 years@Hubro in fairness, I'm not sure that's all bash's fault. You have somewhat complicated matters by using ruby to feed things to bash, and it's not clear to me what part ruby is playing in the stripping or reinforcing of escape characters.
-
Hafizur Rahman over 9 years@MadHatter It ain't Ruby's fault: pastebin.com/6ezCP1HS
-
MadHatter over 9 yearsYou may be right; I don't know enough ruby to understand the intricacies of the
<<<
operator. All I do know is that when bash is used unmediated by anything else, the problem admits of a solution; see above. -
Mukul Goel about 9 years@MadHatter : what to do if ! is part of a password that I am trying to enter and getting this error?
-
Mukul Goel about 9 years@MadHatter Okkie. I will do so.
-
Gavin Ward almost 8 yearsDo you know the reasoning behind the syntax? It seems really counter intuitative. You'd think you'd type
+H
to enable something and-H
to disable something. -
Dennis Williamson almost 8 years@PunkyGuy: I don't know the history (pun intended) behind it, but Unix options typically start with a hyphen (or minus) and
+
is simply the opposite of that. -
ΤΖΩΤΖΙΟΥ almost 8 years
$_
works in more shells than bash and it's a proper variable, unlike!$
. (and @LeartS: I liked your joke's lack of emoticons. ;) ) -
MadHatter over 7 years@MarkusZeller thanks for letting me know; I'm glad this answer is still helping people, six years on!
-
Bodo Thiesen about 6 yearsProbably a bug, because here, I have 4.4.12 and yet again, I need
set +H
or quoting. Or you haveset +H
somewhere (like in/etc/profile
). -
JohnnyD92 almost 6 yearsUsing !-char not at the end of the sentence verifies bash's event detection is still working fine. Version is 4.3.30 ........ $ echo "Recheck your sentence!foo" bash: !foo: event not found
-
leetbacoon over 3 years
echo 'Reboot your instance!'
works as well, as characters in between'
makes the shell interpret them literally. -
Dario Seidl over 3 yearsFrom
help set
(inbash
): "Using + rather than - causes these flags to be turned off." -
Andrew Schulman over 3 yearsThe question was about bash.
-
Gabriel Staples over 3 yearsAfter reading this answer, I learned what I needed, and in this other answer of mine here I demonstrate 2 different ways to escape the
!
char. -
Pavel Šimerda about 3 years@leetbacoon As long as you don't need to expand variables in the error string.
-
leetbacoon almost 3 years@PavelŠimerda Right, however if a variable needs expanding, just end the single quotes and begin your variable, e.g.
echo 'Reboot '"${machine_name}"' now!'
-
Jasen almost 3 years@Hubro
ruby <<< "puts 'Hello, world"'!'"'"
ruby <<< 'puts "Hello, world!"'
-
Robin Khurana about 2 years@MadHatter: how does ruby enter into this at all? We're just talking about bash and bash's built-in echo command here. :-o
-
Robin Khurana about 2 yearsWhile this question correctly addresses bash, since that's what the question asked, I thought I'd mention that in
zsh
, the approximate equivalent isset -K
orsetopt NO_BANG_HIST
(capitalization and underscores optional, but that's how it shows up in the docs, so referencing it that way in case folks want further details). -
MadHatter about 2 years@lindes see comment 5 above, by Hubro, who brought it up.