Как получить название файла linux

Обновлено: 03.07.2024

В этом руководстве для начинающих пользователей мы ознакомимся с основными командами для работы с файлами и каталогами (иногда их еще называют директориями) в Linux-системах.

Требования

Cервер с Ubuntu 20.04

Все команды, описанные ниже, будут работать и в других дистрибутивах Linux.

Расположение каталогов в файловой системе

При входе на сервер, вы, как правило, попадаете в домашний каталог вашей учетной записи, отведенный для хранения файлов и создания директорий.

Для того чтобы узнать, где располагается каталог, в котором мы сейчас находимся, используется команда:

Результат выполнения команды выглядит следующим образом:

Домашний каталог располагается после имени учетной записи пользователя, в приведенном примере он называется /demo. Этот каталог находится в каталоге с именем /home и в каталоге верхнего уровня, который называется root или корневой каталог, поэтому представлен одной косой чертой /.

Просмотр содержимого каталогов

Для просмотра содержимого каталога используется команда ls. Название этой команды является сокращением слов list files.

Просмотреть содержимое любой директории можно следующими способами:

Либо введя команду:

В результате выполнения команды отображаются файлы и каталоги, находящиеся внутри данного каталога:

К команде ls можно добавлять дополнительные флаги, например, чтобы показать детализированное представление (права, список владельцев файлов или папок, размер, дату последнего модифицирования) файлов и директорий в текущей директории, можно использовать флаг -l:

Результат выполнения команды:

Для просмотра списка всех файлов, включая скрытые файлы и каталоги, вы можете добавить флаг -a:

Результат выполнения команды:

Отобразить содержимое текущей директории с добавлением к именам символов, характеризующих тип, можно с помощью команды:

Результат выполнения команды:

Перемещение между каталогами

Для перехода в домашний каталог используется команда cd. Название этой команды является сокращением слов change directory.

Для перехода в домашний каталог пользователя user используется команда:

Для перехода в предыдущую директорию, в которой мы находились до перехода в текущую директорию также используется команда cd.

В Linux-системах каждый файл и каталог находятся в самой верхней директории, которая называется «корневой» и обозначается одним символом слэш /.

Абсолютный путь указывает на расположение каталога по отношению к этой директории верхнего уровня. Это позволяет обращаться к справочникам однозначным образом из любого места в файловой системе.

Каждый абсолютный путь должен начинаться с косой черты — символа слэш /.

Для перехода в директорию уровнем выше используется команда:

Для перехода в директорию двумя уровнями выше:

Операции с файлами и каталогами

Далее приведен список основных команд навигации в консоли Linux.

Создание

Создание файлов производится с помощью команды:

Создание каталогов выполняется с помощью команды вида:

Название этой команды является сокращением слов make directory.

Создание двух каталогов одновременно выполняется с помощью команды:

Для создания дерева каталогов используется команда следующего вида:

Удаление

Для удаления директорий используется команда rmdir имя_директории. Название этой команды является сокращением слов remove directory.

Для удаления файлов используется команда rm. Например, для удаления файла с именем file1 используется команда:

Команда rm также позволяет удалять не только файлы, но и каталоги.

Для удаления директории с именем dir1 со всеми подкаталогами и файлами используется опция -r (от слова recursive):

Можно удалить одновременно две директории со всем их содержимым:

Также можно использовать параметр -f, который означает, что при удалении не будет запрашиваться подтверждение.

Команда для удаления файла будет выглядеть так:

Команда для удаления каталога:

Перемещение

Для перемещения и переименования файлов и каталогов используется команда mv. Название этой команды является сокращением слова move.

Переименовать файл можно с помощью команды:

Для того чтобы переместить файл, используется команда:

Копирование

Для копирования используется команда cp. Название этой команды является сокращением слова copy.

Чтобы скопировать файл file1 и назвать его file2, используется команда:

Для того чтобы копировать директорию dir1 в директорию dir2, используется команда:

Скопировать файл с именем file1 в директорию с именем dir1, можно с помощью команды:

Редактирование файлов

Мы ознакомились с основными командами для работы с каталогами и файлами.

Далее мы изучим, как редактировать файлы и добавлять в них содержание.

Команда nano позволяет работать в одном из самых простых текстовых редакторов командной строки Linux, который занимает весь терминал в течение всего срока его использования.

В результате ввода в терминал команды nano будет открыт чистый файл.

Интерфейс выглядит следующим образом:


В верхней части открывшегося редактора отображается имя приложения и имя файла, который мы редактируем.

В середине должно располагаться содержимое файла, в настоящее время оно пустое.

В нижней части интерфейса расположен ряд комбинаций клавиш, которые указывают с основными элементами управления текстового редактора. Для каждого из них символ ^ означает клавишу CTRL.

Для того чтобы открыть справку используйте сочетание клавиш CTRL-G.

Закрывается справка с помощью сочетания клавиш CTRL-X. После закрытия справки мы возвращаемся к редактированию.

Вводить и редактировать можно любой текст, например, можно ввести: “Hello World!”

Для сохранения внесенных изменений следует нажать сочетание клавиш CTRL-O. Внимание! Это буква О, а не ноль.

Далее система попросит вас ввести либо подтвердить имя файла, который вы хотите сохранить:

Как вы можете видеть, параметры в нижней части окна редактирования также изменились. Они являются контекстными, то есть будут меняться в зависимости от того, что вы пытаетесь сделать.

После ввода имени файла нажмите клавишу ENTER.

Для того чтобы выйти из тестового редактора нажмите сочетание клавиш CTRL-X.

Если вы внесли изменения и не сохранили файл, вам будет предложено сохранить сделанные вами изменения:

Вы можете нажать клавишу Y, чтобы сохранить изменения, клавишу N для отмены изменений и выхода, или сочетание клавиш CTRL-C, чтобы отменить операцию выхода из режима редактирования файла.

Если вы решили сохранить изменения, вам будет предложено сохранить их в том же файле, который был отредактирован.

Нажмите клавишу ENTER, чтобы сохранить файл и выйти из редактора.

Заключение

Мы ознакомились с возможностями просмотра доступных файлов и каталогов, с основными командами для работы с файлами, которые позволяют просматривать, копировать, перемещать и удалять файлы, а также с основами редактирования в текстовом редакторе nano.

Как получить полное (с путём относительно / ) имя файла в одну команду?

Бывает, работаешь в консоли, и нужно скопировать /полный/путь/к/файлу , например, чтобы в соседней консоли использовать его как аргумент для scp . Приходится вызывать pwd , чтобы скопировать путь к текущей папке, и ls , чтобы скопировать имя файла. Можно ли это сделать в одну команду?

3,169 18 18 серебряных знаков 42 42 бронзовых знака

readlink -f покажет /полный/путь/к/файлу.ext , дополнительно "раскрыв" все символические ссылки и заменив их на "канонические" пути. Пример показателен:

Здесь /tmp/baz.ext является симлинком на /tmp/foo/bar.ext .

Предложенное решение работает в Linux и FreeBSD, но не работает в Mac OS - у них там своя атмосфера.

3,169 18 18 серебряных знаков 42 42 бронзовых знака

Предложу вариант чуть понавороченней:

  1. Читаем полный путь
  2. Сразу же копируем его в буфер обмена, предварительно .
  3. . вырезав конечные СR/LF (если не хотим, чтобы они добавлялись при вставке)

Для файлов относительно текущего каталога

или с тем же результатом


6,844 2 2 золотых знака 23 23 серебряных знака 52 52 бронзовых знака

можно, например, подставлять то, что содержится в переменной окружения $PWD (или в любой другой переменной окружения), даже без «команды», а всего лишь клавиатурным сочетанием. если, конечно, ваша оболочка использует gnu/readline для редактирования командной строки.

например, такая команда привяжет к клавиатурному сочетанию alt+o подстановку значения переменной $PWD (и слэша в конце — для удобства) в текущую позицию курсора:

здесь \eo — это и есть alt+o (а, например, \C-o — это ctrl+o ).

чтобы данная привязка создавалась автоматически в каждой сессии оболочки, можно добавить приведённую команду, например, в стартовый скрипт используемой оболочки —

а ещё лучше — добавить строку, которая в примере выше передавалась встроенной команде оболочки bind, прямо в файл


О человечество! Это прекрасно! Всем огромное спасибо, тему можно считать решённой!

правильно! больше, еще больше велосипедов!

расскажи-ка, чем basename не подошел?

закон топикстартера: из 64 предложеных решений будет скрупулёзно выбрано самое вот такое

Это очень юниксвейно, да, на каждый возможный случай — своя утилита. Вот за это я и ненавижу linux. На самом деле лучший вариант из предложенных. Не надо плодить сущности.


На самом деле, я не знаю, что правильнее выбрать, поэтому выбрал то, что мне проще понять. Попробую варианты с седом и бэйснеймом и решу.

Ле. Человек препологающий, что RoR транслируется в js, что-то считает.


т.е. мне действительно интересно

я бы набыдлокодил grep path file | xargs basename

Stil ★★★★★ ( 05.10.14 01:16:32 )
Последнее исправление: Stil 05.10.14 01:19:11 (всего исправлений: 1)

Ни разу не граммарнаци, но 3 ошибки в одном слове, даже для меня пребор. Марш учить уроки, сучка!

сомневаюсь, что он осилит ответить, потому вот:


\K [6] Keep the stuff left of the \K, don't include it in $&

Ты крут, спасибо


Это очень юниксвейно, да, на каждый возможный случай — своя утилита. Вот за это я и ненавижу linux.

а я ненавижу из-за таких как ты пионеров, которые велосипеды придумывают типа sed 's|.*/\([^/]*\)$|\1|'



А sed не отдельная утилита, а встроенная команда bash?
Подсказка: basename входит в coreutils, а sed - отдельный пакет.

Lavos ★★★★★ ( 05.10.14 08:38:31 )
Последнее исправление: Lavos 05.10.14 08:39:42 (всего исправлений: 1)


Это очень юниксвейно, да, на каждый возможный случай — своя утилита.

В GNU find вы можете использовать -printf параметр для этого, например:

Это не работает для меня, когда я использую несколько типов файлов (ключ -o) @ Urchin Нет причин, по которым это должно происходить, если у вас правильная логика (то есть -o имеет более низкий приоритет, чем подразумеваемый -a , поэтому вы часто захотите сгруппировать свои -o аргументы)

Если в вашем поиске нет опции -printf, вы также можете использовать basename:

Цитирование точки с запятой - это еще один способ устранения неоднозначности: . <> ';'

Используйте -execdir который автоматически содержит текущий файл <> , например:

Вы также можете использовать $PWD вместо . (в некоторых системах это не приведет к появлению дополнительной точки спереди).

Если у вас все еще есть лишняя точка, вы можете запустить:

-execdir utility [argument . ] ;

-execdir Первична идентична -exec первичный за исключением того , утилита будет выполнена из каталога, держит текущий файл .

Когда используется + вместо ; , то <> заменяется таким количеством путей, сколько возможно для каждого вызова утилиты. Другими словами, он напечатает все имена файлов в одну строку.

Я получаю ./filename вместо filename . В зависимости от ваших потребностей, это может или не может быть хорошо.

Если вы используете GNU найти

Или вы можете использовать язык программирования, такой как Ruby (1.9+)

Если вам нравится решение bash (как минимум 4)

Если вы хотите выполнить какое-либо действие только с именем файла, использовать basename может быть сложно.

будет просто повторять базовое имя /my/found/path . Не то, что мы хотим, если мы хотим выполнить по имени файла.

Но вы можете затем xargs на выходе. например, чтобы убить файлы в каталоге, основываясь на именах в другом каталоге:

/clang+llvm-3.3/bin/ -type f -exec basename <> \;

На Mac (BSD find ) используйте:

-exec и -execdir медленно, xargs это король.

xargs Параллелизм также помогает.

Как ни странно, я не могу объяснить последний случай xargs без -n1 . Это дает правильный результат, и это самый быстрый ¯\_(ツ)_/¯

( basename принимает только 1 аргумент пути, но xargs отправит их все (на самом деле 5000) без -n1 . не работает на linux и openbsd, только macOS . )

Несколько больших цифр из системы Linux, чтобы увидеть, как это -execdir помогает, но все же намного медленнее, чем параллель xargs :

еще одна точка данных: на openbsd в долгосрочной перспективе find это -execdir становится самым быстрым, поскольку создание новых процессов - относительно дорогая операция.

Честно говоря, basename и dirname решения проще, но вы также можете проверить это:

Как уже отмечали другие, вы можете комбинировать find и basename , но по умолчанию basename программа будет работать только по одному пути за раз, поэтому исполняемый файл придется запускать один раз для каждого пути (используя либо find . -exec или find . | xargs -n 1 ), что потенциально может быть медленным.

Если вы используете -a опцию on basename , то он может принимать несколько имен файлов за один вызов, что означает, что вы можете затем использовать xargs без -n 1 , чтобы сгруппировать пути вместе в гораздо меньшее количество вызовов basename , что должно быть более эффективным.

Вот сравнение времени, между xargs basename -a и xargs -n1 basename версиями. (Для сравнения «похоже на аналогию» время, указанное здесь, указано после первоначального фиктивного запуска, так что они оба выполняются после того, как метаданные файла уже скопированы в кэш ввода / вывода.) Я передал выходные данные в cksum в обоих случаях просто для демонстрации того, что вывод не зависит от используемого метода.

Как вы можете видеть, это действительно намного быстрее, чтобы избежать запуска basename каждый раз.

Читайте также: