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]
sed s/"'"/""/g foo.txt > bar.txt
или в разделе «Редактировать
sed -i s/"'"/""/g foo.txt
на OS X и BSD (в разделе« Редактировать) TOP COMMENT.
sed -i '' s/"'"/""/g foo.txt
Однако вы публикуете, содержит очень мало информации (какая ОС? И т. Д.)
Я думаю, что главное отличие между использованием регулярного выражения состоит в том, требуют ли они соответствия всей последовательности или нет. В случае
, найти
и некоторых других команд 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 $ (цирколоры)
$ echo "duck's" | sed s/\'//
ducks
Но для этого не нужен sed
, чистый раствор bash:
$ abc="duck's"; echo ${abc/\'/}
ducks