Вопрос по tabs, linux, whitespace – Замените пробелы на вкладки в Linux

90

Как заменить пробелы на вкладки в Linux в данном текстовом файле?

Ваш Ответ

8   ответов
0

.

    tr -cs '[:space:]'
На самом деле, с-c он заменяет последовательные символы, которыене пространства. wingedsubmariner
Вопрос о вкладках, это нет ответ. Matthew Read
9

лучшетр команда:

tr [:blank:] \\t

Это очистит вывод, скажем,распаковать -l , для дальнейшей обработки с помощью grep, cut и т. д.

например.,

unzip -l some-jars-and-textfiles.zip | tr [:blank:] \\t | cut -f 5 | grep jar
Я должен использовать кавычки, чтобы заставить его работать:tr '[:blank:]' \\t nachocab
Я нечтобы заставить его работать, нужно использовать кавычки:tr [:blank:] \\t Ömer An
36

что вы можете попробовать с помощью awk

awk -v OFS="\t" '$1=$1' file1

или САС, если вы предпочитаете

sed 's/[:blank:]+/,/g' thefile.txt > the_modified_copy.txt

или даже тр

tr -s '\t' < thefile.txt | tr '\t' ' ' > the_modified_copy.txt

или упрощенная версия решения tr, предложенная Сэмом Бисби

tr ' ' \\t < someFile > someFile
Arg. Мне пришлось использовать метод проб и ошибок, чтобы SED работал. Я понятия не имею, почему я должен был избежать знака плюс, как это:ls -l | sed "s/ \+/ /g" Jess
В вашем примере с sed лучшие практики предписывают использовать tr для замены отдельных символов на sed с целью повышения эффективности / скорости. Кроме того, пример tr намного проще:tr ' ' \\t < someFile > someFile Sam Bisbee
Сawk -v OFS="\t" '$1=$1' file1 Я заметил, что если у вас есть строка, начинающаяся с цифры 0 (например,0 1 2), то строка будет опущена из результата. Nikola Novak
@ Джесс, Вы нашли "правильный синтаксис по умолчанию " регулярное выражение. По умолчанию sed рассматривает одиночный (неэкранированный) знак плюс как простой символ. То же самое верно для некоторых других символов, таких как '?'Вы можете найти больше информации здесь:gnu.org/software/sed/manual/html_node/... , Подобные подробности синтаксиса можно найти здесь (обратите внимание, что это man для grep, а не sed):gnu.org/software/grep/manual/grep.html#Basic-vs-Extended. Victor Yarema
Конечно, tr имеет лучшую производительность, чем sed, но главная причина, по которой я люблю Unix, заключается в том, чтоЕсть много способов сделать что-то. Если вы планируете делать эту замену много раз, вы будете искать решение с хорошей производительностью, но если вы собираетесь сделать это только один раз, вы будете искать решение, которое включает команду, которая заставляет вас чувствовать себя комфортно. Jonathan
2

га в закладки (преобразуются только начальные пробелы):

find . -name "*.js" -exec bash -c 'unexpand -t 4 --first-only "$0" > /tmp/totabbuff && mv /tmp/totabbuff "$0"' {} \;
Проверено в Cygwin на Windows 7. arkod
1

Вы также можете использоватьastyle, Я нашел это весьма полезным, и у него есть несколько вариантов:

Tab and Bracket Options:
   If  no  indentation  option is set, the default option of 4 spaces will be used. Equivalent to -s4 --indent=spaces=4.  If no brackets option is set, the
   brackets will not be changed.

   --indent=spaces, --indent=spaces=#, -s, -s#
          Indent using # spaces per indent. Between 1 to 20.  Not specifying # will result in a default of 4 spaces per indent.

   --indent=tab, --indent=tab=#, -t, -t#
          Indent using tab characters, assuming that each tab is # spaces long.  Between 1 and 20. Not specifying # will result in a default assumption  of
          4 spaces per tab.`
3

мягких вкладок в жесткие вкладки в текстовых файлах.

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

#!/bin/bash

find . -type f -and -not -path './.git/*' -exec grep -Iq . {} \; -and -print | while read -r file; do {
    echo "Converting... "$file"";
    data=$(unexpand --first-only -t 4 "$file");
    rm "$file";
    echo "$data" > "$file";
}; done;
158
Воспользуйтесь программой «Расширить (1)»
UNEXPAND(1)                      User Commands                     UNEXPAND(1)

NAME
       unexpand - convert spaces to tabs

SYNOPSIS
       unexpand [OPTION]... [FILE]...

DESCRIPTION
       Convert  blanks in each FILE to tabs, writing to standard output.  With
       no FILE, or when FILE is -, read standard input.

       Mandatory arguments to long options are  mandatory  for  short  options
       too.

       -a, --all
              convert all blanks, instead of just initial blanks

       --first-only
              convert only leading sequences of blanks (overrides -a)

       -t, --tabs=N
              have tabs N characters apart instead of 8 (enables -a)

       -t, --tabs=LIST
              use comma separated LIST of tab positions (enables -a)

       --help display this help and exit

       --version
              output version information and exit
. . .
STANDARDS
       The expand and unexpand utilities conform to IEEE Std 1003.1-2001
       (``POSIX.1'').
Единственный разумный ответ. Использование perl или awk является полным излишним, если у вас есть специальная команда для него. 9ilsdx 9rvj 0lo
это сработало лучше для меняunexpand --first-only -t 2 ..., Спасибо! Aquarius Power
Я нея думаю, что расширитель будет работать здесь .. он только преобразует ведущие пробелы и только с двумя или более пробелами .. см. здесь:lists.gnu.org/archive/html/bug-textutils/2001-01/msg00025.html olala
Для записи разверните / не развернитестандартные утилиты. kojiro
9

С помощьюPerl:

perl -p -i -e 's/ /\t/g' file.txt
Хотя, конечно, я хотел сделать наоборот: преобразовать табуляцию в два пробела:perl -p -i -e 's/\t/ /g' *.java TimP
Была похожая проблема с заменой последовательных пробелов на одной вкладке. Perl работал работал только с добавлением «+» к регулярному выражению Todd

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