join (Unix)
join — командаUNIX-подобныхоперационных систем, объединяющая строки двух упорядоченныхтекстовых файлов на основе наличия общегополя. По своей функциональности схожа с операторомJoin, используемого в языкеSQL, но оперирует с текстовыми файлами. Даннаяутилита написана Майком Хертелем (англ. Mike Haertel).
Обзор
[править |править код]Командаjoin принимает на входе два текстовых файла и некоторое число аргументов. Если не передаются никакиеаргументы командной строки, то данная команда ищет пары строк в двух файлах, обладающие совпадающим первым полем (последовательностью символов, отличных от пробела), и выводит строку, состоящую из первого поля и содержимого обеих строк.
Аргументы программы определяют, какойсимвол будет использован вместо пробела для разделения полей строки, которые будут проверяться при поиске совпадающих строк, а также выводить несовпавшие строки или нет. Выводить данные можно в третий файл при помощиперенаправления.
Синтаксис
[править |править код]Упрощенно синтаксис можно представить следующим образом:
join [параметры] файл1 файл2
Если в качестве одного из файлов указано «-» (но не обоих сразу!), то в этом случае вместо файла считывается стандартный ввод[1]. Файлы должны быть отсортированы в возрастающем лексикографическом порядке согласно кодировке ASCII, по полям соединения (обычно по первому полю в каждой строке). Результат операции составляют строки, по одной для каждой пары строк из отношений файл1 и файл2, которые имеют одинаковые поля соединения. Как правило, строка результата состоит из общего поля, затем остатка строки отношения файл1, затем остатка строки отношения файл2. По умолчанию разделителем при выводе информации является пробел. В случае стандартных разделителей полей последовательность упорядочения не учитывает начальные пробелы. Если задана опция-t, то все символы являются значимыми. Если имя файла состоит из цифр, оно может провзаимодействовать с опцией-o, стоящей непосредственно перед аргументами-файлами[2].
Пример
[править |править код]В качестве примера можно взять два нижеследующих файла.
Файл 1:
строка1 текст1строка2 текст2
Файл 2:
строка1 текст11строка3 текст3
Командаjoin (без переданных дополнительных параметров) выдаст следующий результат:
строка1 текст1 текст11
Это вызвано тем, что только слово «строка1» встретилось в обоих файлах в качестве первого слова строки.
Лицензия и распространение
[править |править код]Данная программа находится в собственностиФонда свободного программного обеспечения и распространяется без каких-либо гарантий как свободное ПО по лицензииGNU General Public License[1].
Примечания
[править |править код]- ↑12join(1) — Linux man pageАрхивная копия от 1 ноября 2010 наWayback Machine (англ.)
- ↑Руководство по UnixАрхивная копия от 4 марта 2016 наWayback Machine (рус.)
См. также
[править |править код]Литература
[править |править код]- Shelley Powers. Unix Power Tools. — "O'Reilly Media, Inc.", 2003. — P. 417. —ISBN 978-0-596-00330-2.
Ссылки
[править |править код]join(1)— страница справкиman по пользовательским командамGNU/Linux (англ.) (см.:GNU Coreutils)join(1)— страница справкиman по пользовательским командамDarwin иMac OS X (англ.)join(1)— страница справкиman по пользовательским командамFreeBSD (англ.)- join Examples of the unix join command (англ.)