4.3.1. Syntax of String Operators
Operator | Substitution |
---|---|
${ varname :- word } | If varname exists and isn't null, return its value; otherwise return word. Example: ${count:-0} evaluates to 0 if count is undefined. |
${ varname := word} | If varname exists and isn't null, return its value; otherwise set it to word and then return its value. Positional and special parameters cannot be assigned this way. Example: ${count:=0} sets count to 0 if it is undefined. |
${ varname :? message } | If varname exists and isn't null, return its value; otherwise print varname: followed by message, and abort the current command or script (non-interactive shells only). Omitting message produces the default message parameter null or not set. Example: {count:?"undefined!"} prints "count: undefined!" and exits if count is undefined. |
${ varname:+word } |
If
varname exists and isn't null,
return word; otherwise return
null.
Purpose: Testing for the
existence of a variable.
Example: ${count:+1} returns 1 (which
could mean "true") if count
is defined.
|
${ varname:offset:length } |
Performs substring
expansion.[5] It returns the substring of
$varname starting at
offset and up to
length characters. The first
character in $varname is position 0. If
length is omitted, the substring
starts at offset and continues to the
end of $varname. If
offset is less than 0 then the
position is taken from the end of
$varname. If
varname is @, the
length is the number of positional
parameters starting at parameter offset.
Purpose: Returning parts of
a string (substrings or slices).
Example: If count is set to
frogfootman, ${count:4} returns
footman. ${count:4:4} returns
foot.
|
4.3.2. Patterns and Pattern Matching
Operator | Meaning |
---|---|
${variable #pattern} | If the pattern matches the beginning of the variable's value, delete the shortest part that matches and return the rest. |
${variable ##pattern} | If the pattern matches the beginning of the variable's value, delete the longest part that matches and return the rest. |
${variable %pattern} | If the pattern matches the end of the variable's value, delete the shortest part that matches and return the rest. |
${variable %%pattern} | If the pattern matches the end of the variable's value, delete the longest part that matches and return the rest. |
${variable/ pattern/ string}${variable// pattern/ string} | The longest match to pattern in variable is replaced by string. In the first form, only the first match is replaced. In the second form, all matches are replaced. If the pattern begins with a #, it must match at the start of the variable. If it begins with a %, it must match with the end of the variable. If string is null, the matches are deleted. If variable is @ or *, the operation is applied to each positional parameter in turn and the expansion is the resultant list.[6] |
0 件のコメント:
コメントを投稿