What is the difference between `command a[bc]d` and `command `a{b,c}d`Quoting curly braces in the shellIs...
How much cash can I safely carry into the USA and avoid civil forfeiture?
The Defining Moment
A Note on N!
Is there a way to get a compiler for the original B programming language?
Pulling the rope with one hand is as heavy as with two hands?
Why was the Spitfire's elliptical wing almost uncopied by other aircraft of World War 2?
Can I spend a night at Vancouver then take a flight to my college in Toronto as an international student?
How can I practically buy stocks?
What was the first Intel x86 processor with "Base + Index * Scale + Displacement" addressing mode?
In order to check if a field is required or not, is the result of isNillable method sufficient?
What happened to Captain America in Endgame?
Critique of timeline aesthetic
Why do games have consumables?
How exactly does Hawking radiation decrease the mass of black holes?
Is there really no use for MD5 anymore?
Don’t seats that recline flat defeat the purpose of having seatbelts?
Are Boeing 737-800’s grounded?
how to find the equation of a circle given points of the circle
Examples of subgroups where it's nontrivial to show closure under multiplication?
French for 'It must be my imagination'?
How to have a sharp product image?
How to verbalise code in Mathematica?
How to pronounce 'C++' in Spanish
Error message with tabularx
What is the difference between `command a[bc]d` and `command `a{b,c}d`
Quoting curly braces in the shellIs there a Unix command that searches for similar strings, based mostly on how they sound when spoken?Bash expansion of ${@} as commandHow can I suppress the space between generated arguments during brace expansion?Brace expansion and compound commandGrep for word stem and print only word (and not line)Why doesn't systemctl {restart,status} sshd; work?Match lines between two patters using sed just onceExtract data between two patterns from a huge (forced) text fileLog the files found with the linux find and sed command
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ margin-bottom:0;
}
What is the difference between command a[bc]d
and command a{b,c}d
? Why do people use a{b,c}d
when there is already a[bc]d
?
brace-expansion pattern-matching
add a comment |
What is the difference between command a[bc]d
and command a{b,c}d
? Why do people use a{b,c}d
when there is already a[bc]d
?
brace-expansion pattern-matching
Who told you to usecommand a[bc]d
?
– Jesse_b
4 hours ago
It certainly has its uses if one understands it correctly.
– Weijun Zhou
4 hours ago
1
I guess I just don't understand how the confusion between the two happened.
– Jesse_b
4 hours ago
I have been explicitly asked by a coworker less familiar with Linux on this, although not recently.
– Weijun Zhou
4 hours ago
add a comment |
What is the difference between command a[bc]d
and command a{b,c}d
? Why do people use a{b,c}d
when there is already a[bc]d
?
brace-expansion pattern-matching
What is the difference between command a[bc]d
and command a{b,c}d
? Why do people use a{b,c}d
when there is already a[bc]d
?
brace-expansion pattern-matching
brace-expansion pattern-matching
asked 4 hours ago
Weijun ZhouWeijun Zhou
1,750427
1,750427
Who told you to usecommand a[bc]d
?
– Jesse_b
4 hours ago
It certainly has its uses if one understands it correctly.
– Weijun Zhou
4 hours ago
1
I guess I just don't understand how the confusion between the two happened.
– Jesse_b
4 hours ago
I have been explicitly asked by a coworker less familiar with Linux on this, although not recently.
– Weijun Zhou
4 hours ago
add a comment |
Who told you to usecommand a[bc]d
?
– Jesse_b
4 hours ago
It certainly has its uses if one understands it correctly.
– Weijun Zhou
4 hours ago
1
I guess I just don't understand how the confusion between the two happened.
– Jesse_b
4 hours ago
I have been explicitly asked by a coworker less familiar with Linux on this, although not recently.
– Weijun Zhou
4 hours ago
Who told you to use
command a[bc]d
?– Jesse_b
4 hours ago
Who told you to use
command a[bc]d
?– Jesse_b
4 hours ago
It certainly has its uses if one understands it correctly.
– Weijun Zhou
4 hours ago
It certainly has its uses if one understands it correctly.
– Weijun Zhou
4 hours ago
1
1
I guess I just don't understand how the confusion between the two happened.
– Jesse_b
4 hours ago
I guess I just don't understand how the confusion between the two happened.
– Jesse_b
4 hours ago
I have been explicitly asked by a coworker less familiar with Linux on this, although not recently.
– Weijun Zhou
4 hours ago
I have been explicitly asked by a coworker less familiar with Linux on this, although not recently.
– Weijun Zhou
4 hours ago
add a comment |
2 Answers
2
active
oldest
votes
a[bc]d
is a filename pattern. It will expand to abd
and acd
if those are names of existing files in the current directory. If abd
exists, but acd
does not, then it would only expand to abd
, and vice versa. By default, the pattern would remain unexpanded if there was no matching filename.
a{b,c}d
is a brace expansion (in shells that support these). It will expand to the two strings abd
and acd
. This is regardless of whether these strings corresponds to existing filenames or not.
If you are constructing strings, use a brace expansion. If you are matching filenames, use a filename pattern.
Thank you for clarifying "If abd exists, but acd does not, then it would only expand to abd". I guess that is what is missing from my answer.
– Weijun Zhou
3 hours ago
add a comment |
a[bc]d
is pattern-matching, and is part of the POSIX standard. In POSIX, this is introduced as the "pattern bracket expression". It is documented in section 2.13 of the manual
When unquoted and outside a bracket expression, the following three
characters shall have special meaning in the specification of
patterns:
?
A question-mark is a pattern that shall match any character.
*
An asterisk is a pattern that shall match multiple characters, as
described in Patterns Matching Multiple Characters.
[
The open bracket shall introduce a pattern bracket expression.
Section 2.13.3 also mentions something that it behaves differently from what one would expect for usual regexs when it is used for filename expansion (emphasis by me)
The rules described so far in Patterns Matching a Single Character and
Patterns Matching Multiple Characters are qualified by the following
rules that apply when pattern matching notation is used for filename
expansion:
The slash character in a pathname shall be explicitly matched by using
one or more slashes in the pattern; it shall neither be matched by the
asterisk or question-mark special characters nor by a bracket
expression. Slashes in the pattern shall be identified before bracket
expressions; thus, a slash cannot be included in a pattern bracket
expression used for filename expansion. If a slash character is found
following an unescaped open square bracket character before a
corresponding closing square bracket is found, the open bracket shall
be treated as an ordinary character. For example, the pattern
"a[b/c]d" does not match such pathnames as abd or a/d. It only matches
a pathname of literally a[b/c]d.
a{b,c}d
is braces expansion, it is not in the specification by POSIX. Here is the corresponding part from the bash manual (emphasis by me):
Brace expansion is a mechanism by which arbitrary strings may be
generated. This mechanism is similar to filename expansion (see
Filename Expansion), but the filenames generated need not exist.
Patterns to be brace expanded take the form of an optional preamble,
followed by either a series of comma-separated strings or a sequence
expression between a pair of braces, followed by an optional
postscript. The preamble is prefixed to each string contained within
the braces, and the postscript is then appended to each resulting
string, expanding left to right.
According to the comment by @mosvy, this first appeared from csh
but the behavior in bash
is different from csh
and other shells. This type of braces expansion is also present in glob(3)
.
There is another type of braces expansion {a..z}
that only appeared after bash
3.0, and there are more added in bash
4.0.
In a shell where globbing is turned on, execute in a empty folder, the following result is returned
$ echo a[bc]d
a[bc]d
$ echo a{b,c}d
abd acd
In response to @Jesse_b's comment, if you are in an interactive shell and both of them applies, a[bc]d
is less trouble typing. For example grep pattern [ab][12].txt
.
The brace expansion is not a "bashism"; it first appeared incsh
, long beforebash
. It's also present in the glob(3) library function. The difference is that inbash
it's performed before other expansions:a=A; ab=A/B; ac=A/C; echo $a{b,c}
will work in bash differently from any other shell.
– mosvy
2 hours ago
Thank you. I will update the answer.
– Weijun Zhou
2 hours ago
add a comment |
Your Answer
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "106"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f515895%2fwhat-is-the-difference-between-command-abcd-and-command-ab-cd%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
2 Answers
2
active
oldest
votes
2 Answers
2
active
oldest
votes
active
oldest
votes
active
oldest
votes
a[bc]d
is a filename pattern. It will expand to abd
and acd
if those are names of existing files in the current directory. If abd
exists, but acd
does not, then it would only expand to abd
, and vice versa. By default, the pattern would remain unexpanded if there was no matching filename.
a{b,c}d
is a brace expansion (in shells that support these). It will expand to the two strings abd
and acd
. This is regardless of whether these strings corresponds to existing filenames or not.
If you are constructing strings, use a brace expansion. If you are matching filenames, use a filename pattern.
Thank you for clarifying "If abd exists, but acd does not, then it would only expand to abd". I guess that is what is missing from my answer.
– Weijun Zhou
3 hours ago
add a comment |
a[bc]d
is a filename pattern. It will expand to abd
and acd
if those are names of existing files in the current directory. If abd
exists, but acd
does not, then it would only expand to abd
, and vice versa. By default, the pattern would remain unexpanded if there was no matching filename.
a{b,c}d
is a brace expansion (in shells that support these). It will expand to the two strings abd
and acd
. This is regardless of whether these strings corresponds to existing filenames or not.
If you are constructing strings, use a brace expansion. If you are matching filenames, use a filename pattern.
Thank you for clarifying "If abd exists, but acd does not, then it would only expand to abd". I guess that is what is missing from my answer.
– Weijun Zhou
3 hours ago
add a comment |
a[bc]d
is a filename pattern. It will expand to abd
and acd
if those are names of existing files in the current directory. If abd
exists, but acd
does not, then it would only expand to abd
, and vice versa. By default, the pattern would remain unexpanded if there was no matching filename.
a{b,c}d
is a brace expansion (in shells that support these). It will expand to the two strings abd
and acd
. This is regardless of whether these strings corresponds to existing filenames or not.
If you are constructing strings, use a brace expansion. If you are matching filenames, use a filename pattern.
a[bc]d
is a filename pattern. It will expand to abd
and acd
if those are names of existing files in the current directory. If abd
exists, but acd
does not, then it would only expand to abd
, and vice versa. By default, the pattern would remain unexpanded if there was no matching filename.
a{b,c}d
is a brace expansion (in shells that support these). It will expand to the two strings abd
and acd
. This is regardless of whether these strings corresponds to existing filenames or not.
If you are constructing strings, use a brace expansion. If you are matching filenames, use a filename pattern.
edited 3 hours ago
answered 3 hours ago
Kusalananda♦Kusalananda
144k18268448
144k18268448
Thank you for clarifying "If abd exists, but acd does not, then it would only expand to abd". I guess that is what is missing from my answer.
– Weijun Zhou
3 hours ago
add a comment |
Thank you for clarifying "If abd exists, but acd does not, then it would only expand to abd". I guess that is what is missing from my answer.
– Weijun Zhou
3 hours ago
Thank you for clarifying "If abd exists, but acd does not, then it would only expand to abd". I guess that is what is missing from my answer.
– Weijun Zhou
3 hours ago
Thank you for clarifying "If abd exists, but acd does not, then it would only expand to abd". I guess that is what is missing from my answer.
– Weijun Zhou
3 hours ago
add a comment |
a[bc]d
is pattern-matching, and is part of the POSIX standard. In POSIX, this is introduced as the "pattern bracket expression". It is documented in section 2.13 of the manual
When unquoted and outside a bracket expression, the following three
characters shall have special meaning in the specification of
patterns:
?
A question-mark is a pattern that shall match any character.
*
An asterisk is a pattern that shall match multiple characters, as
described in Patterns Matching Multiple Characters.
[
The open bracket shall introduce a pattern bracket expression.
Section 2.13.3 also mentions something that it behaves differently from what one would expect for usual regexs when it is used for filename expansion (emphasis by me)
The rules described so far in Patterns Matching a Single Character and
Patterns Matching Multiple Characters are qualified by the following
rules that apply when pattern matching notation is used for filename
expansion:
The slash character in a pathname shall be explicitly matched by using
one or more slashes in the pattern; it shall neither be matched by the
asterisk or question-mark special characters nor by a bracket
expression. Slashes in the pattern shall be identified before bracket
expressions; thus, a slash cannot be included in a pattern bracket
expression used for filename expansion. If a slash character is found
following an unescaped open square bracket character before a
corresponding closing square bracket is found, the open bracket shall
be treated as an ordinary character. For example, the pattern
"a[b/c]d" does not match such pathnames as abd or a/d. It only matches
a pathname of literally a[b/c]d.
a{b,c}d
is braces expansion, it is not in the specification by POSIX. Here is the corresponding part from the bash manual (emphasis by me):
Brace expansion is a mechanism by which arbitrary strings may be
generated. This mechanism is similar to filename expansion (see
Filename Expansion), but the filenames generated need not exist.
Patterns to be brace expanded take the form of an optional preamble,
followed by either a series of comma-separated strings or a sequence
expression between a pair of braces, followed by an optional
postscript. The preamble is prefixed to each string contained within
the braces, and the postscript is then appended to each resulting
string, expanding left to right.
According to the comment by @mosvy, this first appeared from csh
but the behavior in bash
is different from csh
and other shells. This type of braces expansion is also present in glob(3)
.
There is another type of braces expansion {a..z}
that only appeared after bash
3.0, and there are more added in bash
4.0.
In a shell where globbing is turned on, execute in a empty folder, the following result is returned
$ echo a[bc]d
a[bc]d
$ echo a{b,c}d
abd acd
In response to @Jesse_b's comment, if you are in an interactive shell and both of them applies, a[bc]d
is less trouble typing. For example grep pattern [ab][12].txt
.
The brace expansion is not a "bashism"; it first appeared incsh
, long beforebash
. It's also present in the glob(3) library function. The difference is that inbash
it's performed before other expansions:a=A; ab=A/B; ac=A/C; echo $a{b,c}
will work in bash differently from any other shell.
– mosvy
2 hours ago
Thank you. I will update the answer.
– Weijun Zhou
2 hours ago
add a comment |
a[bc]d
is pattern-matching, and is part of the POSIX standard. In POSIX, this is introduced as the "pattern bracket expression". It is documented in section 2.13 of the manual
When unquoted and outside a bracket expression, the following three
characters shall have special meaning in the specification of
patterns:
?
A question-mark is a pattern that shall match any character.
*
An asterisk is a pattern that shall match multiple characters, as
described in Patterns Matching Multiple Characters.
[
The open bracket shall introduce a pattern bracket expression.
Section 2.13.3 also mentions something that it behaves differently from what one would expect for usual regexs when it is used for filename expansion (emphasis by me)
The rules described so far in Patterns Matching a Single Character and
Patterns Matching Multiple Characters are qualified by the following
rules that apply when pattern matching notation is used for filename
expansion:
The slash character in a pathname shall be explicitly matched by using
one or more slashes in the pattern; it shall neither be matched by the
asterisk or question-mark special characters nor by a bracket
expression. Slashes in the pattern shall be identified before bracket
expressions; thus, a slash cannot be included in a pattern bracket
expression used for filename expansion. If a slash character is found
following an unescaped open square bracket character before a
corresponding closing square bracket is found, the open bracket shall
be treated as an ordinary character. For example, the pattern
"a[b/c]d" does not match such pathnames as abd or a/d. It only matches
a pathname of literally a[b/c]d.
a{b,c}d
is braces expansion, it is not in the specification by POSIX. Here is the corresponding part from the bash manual (emphasis by me):
Brace expansion is a mechanism by which arbitrary strings may be
generated. This mechanism is similar to filename expansion (see
Filename Expansion), but the filenames generated need not exist.
Patterns to be brace expanded take the form of an optional preamble,
followed by either a series of comma-separated strings or a sequence
expression between a pair of braces, followed by an optional
postscript. The preamble is prefixed to each string contained within
the braces, and the postscript is then appended to each resulting
string, expanding left to right.
According to the comment by @mosvy, this first appeared from csh
but the behavior in bash
is different from csh
and other shells. This type of braces expansion is also present in glob(3)
.
There is another type of braces expansion {a..z}
that only appeared after bash
3.0, and there are more added in bash
4.0.
In a shell where globbing is turned on, execute in a empty folder, the following result is returned
$ echo a[bc]d
a[bc]d
$ echo a{b,c}d
abd acd
In response to @Jesse_b's comment, if you are in an interactive shell and both of them applies, a[bc]d
is less trouble typing. For example grep pattern [ab][12].txt
.
The brace expansion is not a "bashism"; it first appeared incsh
, long beforebash
. It's also present in the glob(3) library function. The difference is that inbash
it's performed before other expansions:a=A; ab=A/B; ac=A/C; echo $a{b,c}
will work in bash differently from any other shell.
– mosvy
2 hours ago
Thank you. I will update the answer.
– Weijun Zhou
2 hours ago
add a comment |
a[bc]d
is pattern-matching, and is part of the POSIX standard. In POSIX, this is introduced as the "pattern bracket expression". It is documented in section 2.13 of the manual
When unquoted and outside a bracket expression, the following three
characters shall have special meaning in the specification of
patterns:
?
A question-mark is a pattern that shall match any character.
*
An asterisk is a pattern that shall match multiple characters, as
described in Patterns Matching Multiple Characters.
[
The open bracket shall introduce a pattern bracket expression.
Section 2.13.3 also mentions something that it behaves differently from what one would expect for usual regexs when it is used for filename expansion (emphasis by me)
The rules described so far in Patterns Matching a Single Character and
Patterns Matching Multiple Characters are qualified by the following
rules that apply when pattern matching notation is used for filename
expansion:
The slash character in a pathname shall be explicitly matched by using
one or more slashes in the pattern; it shall neither be matched by the
asterisk or question-mark special characters nor by a bracket
expression. Slashes in the pattern shall be identified before bracket
expressions; thus, a slash cannot be included in a pattern bracket
expression used for filename expansion. If a slash character is found
following an unescaped open square bracket character before a
corresponding closing square bracket is found, the open bracket shall
be treated as an ordinary character. For example, the pattern
"a[b/c]d" does not match such pathnames as abd or a/d. It only matches
a pathname of literally a[b/c]d.
a{b,c}d
is braces expansion, it is not in the specification by POSIX. Here is the corresponding part from the bash manual (emphasis by me):
Brace expansion is a mechanism by which arbitrary strings may be
generated. This mechanism is similar to filename expansion (see
Filename Expansion), but the filenames generated need not exist.
Patterns to be brace expanded take the form of an optional preamble,
followed by either a series of comma-separated strings or a sequence
expression between a pair of braces, followed by an optional
postscript. The preamble is prefixed to each string contained within
the braces, and the postscript is then appended to each resulting
string, expanding left to right.
According to the comment by @mosvy, this first appeared from csh
but the behavior in bash
is different from csh
and other shells. This type of braces expansion is also present in glob(3)
.
There is another type of braces expansion {a..z}
that only appeared after bash
3.0, and there are more added in bash
4.0.
In a shell where globbing is turned on, execute in a empty folder, the following result is returned
$ echo a[bc]d
a[bc]d
$ echo a{b,c}d
abd acd
In response to @Jesse_b's comment, if you are in an interactive shell and both of them applies, a[bc]d
is less trouble typing. For example grep pattern [ab][12].txt
.
a[bc]d
is pattern-matching, and is part of the POSIX standard. In POSIX, this is introduced as the "pattern bracket expression". It is documented in section 2.13 of the manual
When unquoted and outside a bracket expression, the following three
characters shall have special meaning in the specification of
patterns:
?
A question-mark is a pattern that shall match any character.
*
An asterisk is a pattern that shall match multiple characters, as
described in Patterns Matching Multiple Characters.
[
The open bracket shall introduce a pattern bracket expression.
Section 2.13.3 also mentions something that it behaves differently from what one would expect for usual regexs when it is used for filename expansion (emphasis by me)
The rules described so far in Patterns Matching a Single Character and
Patterns Matching Multiple Characters are qualified by the following
rules that apply when pattern matching notation is used for filename
expansion:
The slash character in a pathname shall be explicitly matched by using
one or more slashes in the pattern; it shall neither be matched by the
asterisk or question-mark special characters nor by a bracket
expression. Slashes in the pattern shall be identified before bracket
expressions; thus, a slash cannot be included in a pattern bracket
expression used for filename expansion. If a slash character is found
following an unescaped open square bracket character before a
corresponding closing square bracket is found, the open bracket shall
be treated as an ordinary character. For example, the pattern
"a[b/c]d" does not match such pathnames as abd or a/d. It only matches
a pathname of literally a[b/c]d.
a{b,c}d
is braces expansion, it is not in the specification by POSIX. Here is the corresponding part from the bash manual (emphasis by me):
Brace expansion is a mechanism by which arbitrary strings may be
generated. This mechanism is similar to filename expansion (see
Filename Expansion), but the filenames generated need not exist.
Patterns to be brace expanded take the form of an optional preamble,
followed by either a series of comma-separated strings or a sequence
expression between a pair of braces, followed by an optional
postscript. The preamble is prefixed to each string contained within
the braces, and the postscript is then appended to each resulting
string, expanding left to right.
According to the comment by @mosvy, this first appeared from csh
but the behavior in bash
is different from csh
and other shells. This type of braces expansion is also present in glob(3)
.
There is another type of braces expansion {a..z}
that only appeared after bash
3.0, and there are more added in bash
4.0.
In a shell where globbing is turned on, execute in a empty folder, the following result is returned
$ echo a[bc]d
a[bc]d
$ echo a{b,c}d
abd acd
In response to @Jesse_b's comment, if you are in an interactive shell and both of them applies, a[bc]d
is less trouble typing. For example grep pattern [ab][12].txt
.
edited 2 hours ago
answered 4 hours ago
Weijun ZhouWeijun Zhou
1,750427
1,750427
The brace expansion is not a "bashism"; it first appeared incsh
, long beforebash
. It's also present in the glob(3) library function. The difference is that inbash
it's performed before other expansions:a=A; ab=A/B; ac=A/C; echo $a{b,c}
will work in bash differently from any other shell.
– mosvy
2 hours ago
Thank you. I will update the answer.
– Weijun Zhou
2 hours ago
add a comment |
The brace expansion is not a "bashism"; it first appeared incsh
, long beforebash
. It's also present in the glob(3) library function. The difference is that inbash
it's performed before other expansions:a=A; ab=A/B; ac=A/C; echo $a{b,c}
will work in bash differently from any other shell.
– mosvy
2 hours ago
Thank you. I will update the answer.
– Weijun Zhou
2 hours ago
The brace expansion is not a "bashism"; it first appeared in
csh
, long before bash
. It's also present in the glob(3) library function. The difference is that in bash
it's performed before other expansions: a=A; ab=A/B; ac=A/C; echo $a{b,c}
will work in bash differently from any other shell.– mosvy
2 hours ago
The brace expansion is not a "bashism"; it first appeared in
csh
, long before bash
. It's also present in the glob(3) library function. The difference is that in bash
it's performed before other expansions: a=A; ab=A/B; ac=A/C; echo $a{b,c}
will work in bash differently from any other shell.– mosvy
2 hours ago
Thank you. I will update the answer.
– Weijun Zhou
2 hours ago
Thank you. I will update the answer.
– Weijun Zhou
2 hours ago
add a comment |
Thanks for contributing an answer to Unix & Linux Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f515895%2fwhat-is-the-difference-between-command-abcd-and-command-ab-cd%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Who told you to use
command a[bc]d
?– Jesse_b
4 hours ago
It certainly has its uses if one understands it correctly.
– Weijun Zhou
4 hours ago
1
I guess I just don't understand how the confusion between the two happened.
– Jesse_b
4 hours ago
I have been explicitly asked by a coworker less familiar with Linux on this, although not recently.
– Weijun Zhou
4 hours ago