как удалить апостроф и удалить пространство

HOMEDRIVE=E:
HOMEPATH=\Users\Administrator

Видимо, вы имели в виду [1172534]переименование[1172535] - извините за недоразумение.

Но если это так... скажем 374 - 378 ...

Что касается вашего комментария выше - предположим, что они находятся в одном каталоге, и это единственные файлы, которые будут совпадать с [1172536]SSt12.precip.*.sub.climatology.ctl[1172537] там:

Я переименовал их с [1172538]echo[1172539] выше, так что вы не будете сожалеть о моем счету. В своем нынешнем виде он просто покажет, что хочет сделать. Удалите [1172540]echo[1172541] и файлы будут вашими для перемещения или проигрыша.

             total       used       free     shared    buffers     cached
Mem:       3083924    2177300     906624          0     461344     837008
-/+ buffers/cache:     878948    2204976
Swap:      4000148          0    4000148

Смотрите комментарий Стефана ниже для примечания о правильном порядке сортировки - он прав.[1172197]

1
23.09.2014, 18:48
2 ответа
sed s/"'"/""/g foo.txt > bar.txt

или в разделе «Редактировать

sed -i s/"'"/""/g foo.txt

на OS X и BSD (в разделе« Редактировать) TOP COMMENT.

sed -i '' s/"'"/""/g foo.txt

Однако вы публикуете, содержит очень мало информации (какая ОС? И т. Д.)

0
27.01.2020, 23:17

Я думаю, что главное отличие между использованием регулярного выражения состоит в том, требуют ли они соответствия всей последовательности или нет. В случае , найти и некоторых других команд bash вы должны соответствовать всей последовательности, в то время как в sed , awk , grep и так далее вы должны соответствовать любой части последовательности. Кроме того, они похожи, но, конечно, не идентичны.

Например, при использовании регулярного выражения в операторах case оболочки bash предполагается, что регулярное выражение описывает весь ряд. Т.е. (я использую пример здесь )

case $SERVER in
db-[0-9]+\.host\.com) echo "DB server"
;;
*)echo "Unknown server"
;;
esac

Вы можете видеть, что db- [0-9] + .host.com описывает последовательность, которая начинается с «db-», затем имеет одну или несколько цифр, а затем заканчивается на «. host.com», так что db-1.host.com будет совпадать, в то время как xdb-1.host.com не будет.

Теперь, если вы посмотрите на sed , и написать образец поиска в аналогичном пути

echo "xdb-1.host.com"| sed -nr '/db-[0-9]+\.host\.com/p'

sed , в отличие от case команды, БУДЕТ напечатать строку xdb-1.host.com, потому что он может найти поиск образца INSIDE этого ряда. Итак, идея не в том, чтобы соответствовать всей последовательности, а в том, чтобы найти любое вхождение образца.

В аналогичном пути при использовании команды regexp в find вся последовательность должна совпадать. Например,

find / -regextype sed -regex ".*\.dat"

найдет все файлы с данными расширения. Но если вы попытаетесь выполнить тот же поиск с sed ,

find / | sed -nr '/.*\.dat/'

он будет соответствовать всем файлам, которые содержат последовательность «.dat» в имени файла.

Конечно, существуют некоторые незначительные синтаксические различия. Например, если вы делаете

find / -name "*.dat"

это также своего рода регулярное выражение, где * означает «любое количество произвольных символов», но в строгом смысле regexp вы должны написать. «*,» где «.» означает любой символ, и * означает любое количество символов рода «»., так что вместе означает любое количество любых символов.

-121--217760-

Если вы просто хотите выделить скрытые файлы (и папки), и вас не волнует раскраска всех остальных файлов, то очевидный подход состоит в том, чтобы запустить ls -la | grep -E «^ |\. [^/| '.]. *»

Если вы хотите сохранить другие цвета, то все начинает усложняться, потому что $ LS _ COLORS изначально не поддерживает раскраску скрытых файлов, как это

Я предложил динамически добавлять скрытые файлы текущего каталога к переменной среды $ LS _ COLORS в качестве псевдо-расширения, затем выполнять ls -la и после этого запускать dircolors для сброса исходной цветовой схемы. Очевидно, что возникнет конфликт, если скрытый файл будет иметь то же имя, что и известное расширение. Также этот метод не работает со скрытыми папками.

Внимание! Это решение является (не очень тщательно протестированным) взломом. Используйте его на свой страх и риск.

для h в $ (ls -A | grep «^\».); делать LS_COLORS="$LS_COLORS*$h=04;05:"; готово; ls -la; eval $ (цирколоры)

-121--42302-
$ echo "duck's" | sed s/\'//
ducks

Но для этого не нужен sed , чистый раствор bash:

$ abc="duck's"; echo ${abc/\'/}
ducks
5
27.01.2020, 23:17

Теги

Похожие вопросы