J'ai une ficelle comme ça:
|abcdefg|
Et je veux obtenir une nouvelle chaîne appelée quelque part (comme chaîne2) avec la chaîne originale sans les deux |
caractères au début et à la fin, de façon à avoir ceci:
abcdefg
Est-ce possible à Bash?
J'ai une ficelle comme ça:
|abcdefg|
Et je veux obtenir une nouvelle chaîne appelée quelque part (comme chaîne2) avec la chaîne originale sans les deux |
caractères au début et à la fin, de façon à avoir ceci:
abcdefg
Est-ce possible à Bash?
Réponses:
Tu peux faire
string="|abcdefg|"
string2=${string#"|"}
string2=${string2%"|"}
echo $string2
Ou si votre longueur de chaîne est constante, vous pouvez faire
string="|abcdefg|"
string2=${string:1:7}
echo $string2
En outre, cela devrait fonctionner
echo "|abcdefg|" | cut -d "|" -f 2
Aussi cette
echo "|abcdefg|" | sed 's/^|\(.*\)|$/\1/'
awk
solutions sympas . J'ai besoin d'apprendre awk
.
IFS='|' read string2 <<< $string
:)
"${string:1:-1}"
man bash
.
Après quelques articles listés ici, il semble que le moyen le plus simple de le faire est:
string="|abcdefg|"
echo ${string:1:-1}
edit: fonctionne sur Ubuntu avec Bash 4.2; ne fonctionne pas sur centOS avec bash 4.1
Une autre façon est d'utiliser head
& tail
commandes:
$ echo -n "|abcdefg|" | tail -c +2 | head -c -2
abcdefg
[something something]
but avec l'objectif de couper les crochets, donc j'ai bien echo "[something something]" | tail -c +2 | head -c -2
travaillé. Merci pour un tuyau!
echo -n "|abcdefg|" | tail -c +2 | head -c -1
. Je ne suis pas sûr de savoir pourquoi mes modifications ont été rejetées ... C'est très triste, pour être honnête. Voir man head
pour plus d'informations
Et un autre:
string="|abcdefg|"
echo "${string//|/}"
Vous pouvez également utiliser sed pour supprimer le | pas simplement en référençant le symbole lui-même mais en utilisant des références de position comme dans:
$ echo "|abcdefg|" | sed 's:^.\(.*\).$:\1:'
abcdefg
Où ':' sont les délimiteurs (vous pouvez les remplacer par tout caractère ne figurant pas dans la requête, tout signe suivant le s le fera) Ici ^ (caret) signifie au début de la chaîne d'entrée et $ (dollar) signifie à la fin. Le . (point) que c'est après le curseur et celui qui est avant le signe dollar représente un seul caractère. En d'autres termes, nous supprimons les premier et dernier caractères. Gardez à l'esprit que cela supprimera tous les caractères, même si | ce n'est pas présent dans la chaîne.
EX:
$ echo "abcdefg" | sed 's:^.\(.*\).$:\1:'
bcdef
Une approche un peu plus verbeuse, mais qui fonctionne sur tous les types de premier et dernier caractères, ne doit pas nécessairement être identique. L'idée de base est que nous prenons une variable, la lisons caractère par caractère et ajoutons uniquement ceux que nous souhaitons à une nouvelle variable.
Voici toute cette idée formatée dans une fonction intéressante
crop_string_ends() {
STR="$1"
NEWSTR=""
COUNT=0
while read -n 1 CHAR
do
COUNT=$(($COUNT+1))
if [ $COUNT -eq 1 ] || [ $COUNT -eq ${#STR} ]
then
continue
fi
NEWSTR="$NEWSTR"$CHAR
done <<<"$STR"
echo $NEWSTR
}
Et voici la même fonction en action:
$> crop_string_ends "|abcdefg|"
abcdefg
$> crop_string_ends "HelloWorld"
elloWorl
>>> mystring="|abcdefg|"
>>> print(mystring[1:-1])
abcdefg
ou en ligne de commande:
$ python -c 'import sys;print sys.stdin.read()[1:-2]' <<< "|abcdefg|"
abcdefg
$ echo "|abcdefg|" | awk '{print substr($0,2,length($0)-2)}'
abcdefg
$ ruby -ne 'print $_.split("|")[1]' <<< "|abcdefg|"
abcdefg
$ string="|abcdefg|"
$ string="${string#?}" && string="${string%%?}"
$ echo "$string"
abcdefg
De http://tldp.org/LDP/abs/html/parameter-substitution.html
${var#Pattern}
Supprimer de$var
la partie la plus courte de$Pattern
celle qui correspond à l' extrémité avant de$var
. Supprimer de la partie la plus longue de celle qui correspond à la fin de .
${var%%Pattern}
$var
$Pattern
$var
awk -F\| '{ print $2 }' <<<"|string|"