J'ai découvert qu'avec ${string:0:3}
on peut accéder aux 3 premiers caractères d'une chaîne. Existe-t-il une méthode tout aussi simple pour accéder aux trois derniers caractères?
125
Trois derniers caractères de string
:
${string: -3}
ou
${string:(-3)}
(attention à l'espace entre :
et -3
dans la première forme).
Veuillez vous référer à l' extension des paramètres du shell dans le manuel de référence :
${parameter:offset}
${parameter:offset:length}
Expands to up to length characters of parameter starting at the character
specified by offset. If length is omitted, expands to the substring of parameter
starting at the character specified by offset. length and offset are arithmetic
expressions (see Shell Arithmetic). This is referred to as Substring Expansion.
If offset evaluates to a number less than zero, the value is used as an offset
from the end of the value of parameter. If length evaluates to a number less than
zero, and parameter is not ‘@’ and not an indexed or associative array, it is
interpreted as an offset from the end of the value of parameter rather than a
number of characters, and the expansion is the characters between the two
offsets. If parameter is ‘@’, the result is length positional parameters
beginning at offset. If parameter is an indexed array name subscripted by ‘@’ or
‘*’, the result is the length members of the array beginning with
${parameter[offset]}. A negative offset is taken relative to one greater than the
maximum index of the specified array. Substring expansion applied to an
associative array produces undefined results.
Note that a negative offset must be separated from the colon by at least one
space to avoid being confused with the ‘:-’ expansion. Substring indexing is
zero-based unless the positional parameters are used, in which case the indexing
starts at 1 by default. If offset is 0, and the positional parameters are used,
$@ is prefixed to the list.
Puisque cette réponse obtient quelques vues régulières, permettez - moi d 'ajouter une possibilité de répondre au commentaire de John Rix ; comme il le mentionne, si votre chaîne a une longueur inférieure à 3, se ${string: -3}
développe en une chaîne vide. Si, dans ce cas, vous souhaitez l'extension de string
, vous pouvez utiliser:
${string:${#string}<3?0:-3}
Cela utilise l' ?:
opérateur ternaire if, qui peut être utilisé dans Shell Arithmetic ; puisque comme documenté, le décalage est une expression arithmétique, ceci est valide.
deppfx@localhost:/tmp$ echo ${$(hostname): -3}
-bash: ${$(hostname): -3}: bad substitution
temp=$(hostname); echo "${temp: -3}"
. Bash a également laHOSTNAME
variable (qui peut ou non différer de la sortie dehostname
). Si vous voulez l'utiliser, faites-leecho "${HOSTNAME: -3}"
.some func | echo ${string: -3}
- comment attribuer la sortie desome func
àstring
?string=$(some func)
et ensuiteecho "${string: -3}"
.Vous pouvez utiliser
tail
:Une façon quelque peu détournée d'obtenir les trois derniers caractères serait de dire:
la source
Une autre solution de contournement consiste à utiliser
grep -o
avec un peu de magie regex pour obtenir trois caractères suivis de la fin de la ligne:Pour obtenir éventuellement les 1 à 3 derniers caractères, dans le cas de chaînes de moins de 3 caractères, vous pouvez utiliser
egrep
avec cette expression régulière:Vous pouvez également utiliser différentes plages, par exemple
5,10
pour obtenir les cinq à dix derniers caractères.la source
Pour généraliser la question et la réponse de gniourf_gniourf (car c'est ce que je cherchais), si vous voulez couper une plage de caractères de, disons, 7e de la fin au 3e de la fin, vous pouvez utiliser cette syntaxe:
Où 4 est la longueur du cours (7-3).
De plus, alors que la solution de gniourf_gniourf est évidemment la meilleure et la plus soignée, je voulais juste ajouter une solution alternative utilisant cut :
Ceci est plus lisible si vous le faites en deux lignes en définissant la longueur $ {# string} comme une variable séparée.
la source
cut
approche consistant à calculer d'abord le démarrage / l'arrêt, puis à utiliser simplement ces variables dans l'expansion des paramètres (il convient également de mentionner que lescut
décalages et bash commencent à 1 et zéro, respectivement, donc cela aurait besoin à figurer dans les calculs, ce que je ne fais pas ici):start=$((${#string}-3)); stop=$((${#string}));
puisecho ${string: $start : $stop}
vsecho $string | cut -c "$start"-"$stop"