2013-11-01 3 views

ответ

53

Это один из способов с sed:

$ echo $file | sed 's/[^0-9]*//g' 
123 
$ echo "123 he23llo" | sed 's/[^0-9]*//g' 
12323 

Или с чистым bash:

$ echo "${file//[!0-9]/}" 
123 
$ file="123 hello 12345 aaa" 
$ echo "${file//[!0-9]/}"  
12312345 

Чтобы сохранить результат в самой переменной, не

$ file=$(echo $file | sed 's/[^0-9]*//g') 
$ echo $file 
123 

$ file=${file//[!0-9]/} 
$ echo $file 
123 
+1

В интересах полноты, вы можете также сохранить результат обратно в ту же переменную с pure bash form: 'file = $ {file // [! 0-9] /}'. Кроме того, вы можете, в общем, заменить 'echo' * something * '|' * command * на * command * '<<<' * something *. –

+0

Хорошая точка, @MarkReed. В зависимости от типа пользователя, я предпочитаю оставить ответ очень наивным, поскольку '<<<' может быть странным для людей, начинающих bash-script. Я обновляю свой ответ с помощью файла 'file = $ file {file // [! 0-9] /}', большое спасибо! – fedorqui

+0

Ищете это для строки версии (например, 'git version 1.7.1')? Используйте '$ {gitVersion // [! 0-9.] /}' И сохраняем периоды. – bbodenmiller

3

Вы можете сказать, :

echo ${file%%[^0-9]*} 

Однако, это сталкивается с проблемами в некоторых случаях:

$ file="123 file 456" 
$ echo ${file%%[^0-9]*} 
123 

Использование tr:

$ file="123 hello 456" 
$ new=$(tr -dc '0-9' <<< $file) 
$ echo $new 
123456 
+0

Похоже, что-то ** ужасно ** неправильно с этим ответом! – devnull

+0

"определенные случаи"? '$ {file %% [^ 0-9] *}' всегда будет удалять все, начиная с первой не-цифры до конца строки. '%%' не то, что вы хотите здесь вообще (равно как '%' или '#' или '##'). Я чувствую, что здесь не хватает шутки. –

+0

Дорогой @MarkReed, я думал, что то, что вы говорите, было ясно указано в самом ответе или нет? Вероятно, именно поэтому был предложен другой подход. Я что-то упустил? – devnull

Смежные вопросы