Рейтинг:0

Преобразуйте выходной файл со следующими столбцами в CSV, удалив каналы

флаг in

Это то, что у меня есть в моем выходном файле:

    v6_ntoa | v6_ntoa | идентификатор | client_syn_packets
---------------+--------------+-------------+----- ---------------
 105.245.90.61 | 82.17.112.84 | 15426766476 | 1

Я хотел бы, чтобы это было преобразовано в файл csv в следующем формате:

105.245.90.61,82.17.112.84,15426766476,1

Нужна ваша помощь, пожалуйста (sed, awk или любым другим способом). Я пробовал несколько разных способов, но не смог удалить трубы и правильное расстояние.

флаг hr
Есть только одна строка данных? Вы хотите сохранить информацию заголовка?
флаг in
не нужно хранить информацию заголовка. да, это одна строка данных
флаг gi
вы пробовали мое решение? https://askubuntu.com/a/1395720/796708
Рейтинг:1
флаг gi

С использованием Миллер и хвост, и бег

<input.txt хвост -n +3 | млр --csv --ifs "|" -N убрать пробел

у тебя есть

105.245.90.61,82.17.112.84,15426766476,1

Некоторые примечания:

  • <input.txt хвост -n +3 для вывода только той записи, которую вы хотите
  • --если "|", чтобы установить разделитель полей
  • чтобы не устанавливать ввод и вывод заголовка
  • чистые пробелы для очистки пробелов
Рейтинг:0
флаг hr

Наверное самый простой:

$ sed -n '3s/ *| */,/gp' файл
 195.245.90.61,62.17.112.84,15426766476,1

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

Если вы хотите пофантазировать, используйте GNU awk и определите поле как любую последовательность символов, отличных от пробела или черты:

$ gawk 'НАЧАТЬ{FPAT="[^ |]+"; OFS=","} NR==3{$1=$1; распечатать файл
195.245.90.61,62.17.112.84,15426766476,1

или сохранить заголовки

$ gawk 'НАЧАТЬ{FPAT="[^ |]+"; OFS=","} NR%2{$1=$1; распечатать файл
v6_ntoa, v6_ntoa, идентификатор, client_syn_packets
195.245.90.61,62.17.112.84,15426766476,1

Ответить или комментировать

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