копировать файлы на новое имя – кратчайший путь

В каталоге у меня около 150 файлов с определенным расширением, например:

abc.ext def.ext ghi.ext ... 

Теперь я хочу скопировать все эти файлы также в новое имя файла (без расширения):

 abc def ghi 

Каков самый короткий способ сделать это? Возможно ли это без написания цикла в файле bash?

Редактировать: Спасибо за ваши ответы (dirkt, John Newman).
Увидев ответы, я буду придерживаться более короткого, хотя у него есть петля.

  • Как установить программу EMIRGE для записи файлов с требуемым разрешением
  • Linux общий FTP: нельзя удалять один файл
  • Как отобразить разрешения нового файла в строке состояния редактора Vim?
  • Замена строк в файлах с содержимым файла
  • Как touch -t работает внутри?
  • Как передать (на USB-накопитель) или прочитать файл .odt в командной строке?
  • Как редактировать несколько файлов в VIM?
  • Системные файлы со строгими разрешениями
  • 2 Solutions collect form web for “копировать файлы на новое имя – кратчайший путь”

    Это возможно без написания сценария («файл bash»), но не без использования цикла:

     for f in *.ext ; do cp -- "$f" "$(basename "$f" .ext)" ; done 

    basename можно использовать для удаления суффикса.

    Это возможно без цикла. Это хорошо … Я оставлю это до вас.

     $ find . -type f -name "*.ext" -print0 | xargs -0 -I {} echo cp -T {} {}SUB | sed -e 's/\.extSUB//g' 

    добавьте трубу в ш, чтобы выйти из режима сухого хода. Backticks не являются хорошими, поскольку он разделяет новые строки, если вы не имеете дело с $ IFS. Есть и другие проблемы с обратными тактами, как упоминалось выше. Также нужен cp -T, поскольку последний аргумент обычно ожидает каталог.

    Мне не хватает «rep», чтобы прокомментировать сказанное выше, но вы можете использовать различные трюки с bash ${} чтобы избежать fork basename .

    Подстрока: ${f:0:-4} или самое длинное совпадение: ${f%%.ext}

    Linux и Unix - лучшая ОС в мире.