![]() |
AWK (shell, Linux)
Вопрос такой возник по awk-у, может есть простые решения.
Есть файл формата: поле1 "поле 2" поле3 поле1 "поле 2" поле3 .... и т.д. Естественно, строковое поле "поле 3" разбивается на два. В итоге имеем $1 = поле1 $2 = "поле $3 = 2" $4 = поле3 А хотелось бы: $1 = поле1 $2 = "поле 2" $3 = поле3 Заниматься тем, что самому парсить $0 и вытаскивать отдельно значения в кавычках не улыбает, тем более, что пробел между кавычек может быть не один (или вообще табулятор). Есть ли более простые решения при помощи изменения, к примеру, FS или как-то еще? ps: к man awk не отсылать. Не нашел я там ничего по этому поводу. =) pps: интересуют решения только для awk. |
cat testfile |awk 'BEGIN {FS="\""}; {print $1, $2, $3}'
и все-таки man awk :) |
Цитата:
поле1 "поле 2" "поле 3" |
это не "немного другая", это совсем другая.
а в следующий раз что будет, бинарный файл? :) |
Цитата:
|
ты лучше файл выложи, а то мало ли, чего там еще ты забыл :)
|
Цитата:
Так что может верить на слово, строки файла аля: число число "какой-то текст" "еще какой-то текст" число число.... |
ну я ж говорил :) у тебя все вперемешку идет, что ли? выше ты нарисовал так, как будто у тебя строго три поля в строке.
и что это у тебя за работа, на которую удаленно зайти нельзя? |
Цитата:
|
так ты можешь хотя бы кусок реального файла показать? ну или сочинить, но чтобы он был таким же, как в реале. издеваться над $0 смысла нет, не для этого awk придуман.
|
Текущее время: 17:33. Часовой пояс GMT +3. |
Powered by vBulletin® Version 3.8.12 by vBS
Copyright ©2000 - 2025, vBulletin Solutions, Inc. Перевод: zCarot