Bash – обработка вывода по одной строке за раз

Я читал, что xargs хорош для обработки вывода команды по одной строке за раз (и это). У меня есть следующая строка в моем скрипте.

./gen-data | awk '{printf $2 " "; printf $1=$2=$3=""; gsub (" ", "", $0);if(length($0) == 0){ print "0000"} else{print $0}}' | xargs -t -n2 -P1 bash -c 'datatojson "$@"' _ 

Он производит правильный вывод, и в этом нет сомнений. Однако gen-data создает что-то вроде 1000 строк, и мне действительно хотелось бы, чтобы эта команда выполнялась после каждой строки, а не после 1000 строк (она явно останавливается регулярно, чтобы получить больше ввода).

  • Как получить список идентификаторов процессов в системе в командной строке linux?
  • Универсальный инструмент командной строки командной строки на Mac
  • Я не могу изменить системные файлы из CMD
  • Задайте длину вкладки в cmd.exe
  • OS X: кодировка Base64 через командную строку
  • Как просмотреть историю командной строки после закрытия окна в Windows 10?
  • Вот как выглядят gen-data:

     candump $interface & while true; do while read p; do cansend $interface $(echo $p | awk 'NF>1{print $NF}'); done < <(shuf $indoc) done 

    ( cansend отправляет данные в интерфейс, и считывание candump считывается с этого интерфейса и выводит его на экран, но я ставлю это не слишком актуально). В любом случае, кажется, что candump непрерывно выводится на выходе, но когда я xargs его к awk и xargs , он становится фрагментированным. Это просто потому, что я использовал shuf ? Я бы подумал, что, поскольку он проходит через интерфейс и читается с другой стороны, он будет менее фрагментирован, чем предоставляет shuf.

  • Глобальные ярлыки KDE перестали работать. Проблемы с KDED?
  • Gpaste получить как STDIN для youtube-dl
  • Как удалить службы systemd
  • Экспорт Synology NFSv4 с отображением идентификатора
  • ACL vs стандартные разрешения файлов - которые используются при доступе к файлу?
  • Как я могу выйти из открытой, удаленной сессии SSH?
  • One Solution collect form web for “Bash – обработка вывода по одной строке за раз”

    Вы можете попробовать ту же команду, на этот раз используя несколько хаков, чтобы избежать буферизации :

     ./gen-data | gawk '{printf $2 " "; printf $1=$2=$3=""; gsub (" ", "", $0);if(length($0) == 0){ print "0000"} else{print $0}; fflush(stdout)}' | stdbuf -o0 xargs -t -n2 -P1 bash -c 'datatojson "$@"' _ 

    Имейте в виду изменение от awk до gawk и использования fflush . Вы также можете попробовать mawk -Winteractive . Также помните, что я добавил stdbuf -o0 перед xargs. Вы также можете попробовать последнее в начале с ./gen-data

    Давайте будем гением компьютера.