Каков наиболее эффективный способ преобразования данных, разделенных табуляцией, например:
a b c d cat
NULL NULL NULL NULL NULL
NULL NULL NULL d d
NULL NULL c NULL c
NULL NULL c d c; d
NULL b NULL NULL b
NULL b NULL d b; d
NULL b c NULL b; c
NULL b c d b; c; d
a NULL NULL NULL a
a NULL NULL d a; d
a NULL c NULL a; c
a NULL c d a; c; d
a b NULL NULL a; b
a b NULL d a; b; d
a b c NULL a; b; c
a b c d a; b; c; d
Нечто близкое к этому:
a | b | c | d | cat
-----+------+------+------+-----------
NULL | NULL | NULL | NULL | NULL
NULL | NULL | NULL | d | d
NULL | NULL | c | NULL | c
NULL | NULL | c | d | c; d
NULL | b | NULL | NULL | b
NULL | b | NULL | d | b; d
NULL | b | c | NULL | b; c
NULL | b | c | d | b; c; d
a | NULL | NULL | NULL | a
a | NULL | NULL | d | a; d
a | NULL | c | NULL | a; c
a | NULL | c | d | a; c; d
a | b | NULL | NULL | a; b
a | b | NULL | d | a; b; d
a | b | c | NULL | a; b; c
a | b | c | d | a; b; c; d
В настоящее время я использую Notepad ++ следующим образом:
- Преобразовать вкладки в пробелы
- Выровняйте данные вручную
- Используйте режим столбца, чтобы вставить трубы
Второй шаг - самый утомительный, и я бы предпочел автоматизировать хотя бы эту часть.
Примечание: я использую браузер при работе, и иногда у меня открыт текстовый редактор. Эффективное решение - это то, которое требует минимальных усилий. Я могу использовать:
- Notepad ++
- Универсальный текстовый редактор с поддержкой регулярных выражений поиск / замена
- JavaScript набран внутри консоли браузера
- Интернет-сервис онлайн
- PHP в командной строке (
php -a
)
awk
сценарий.
{{(⊃⍵)⍪⍉⍪↑¨↓⍉↑1↓⍵}s¨'⎕T'⎕T¨(s←1↓¨⊢⊂⍨⊢=⊃)¯1⌽⍵}
кажется, достаточно хорош для работы, а?)