Print all Fields with AWK separated by OFS

2019-01-22 12:45发布

Is there a way to print all records separated by the OFS without typing out each column number.

#Desired style of syntax, undesired result
[kbrandt@glade: ~] echo "1 2 3 4" | gawk 'BEGIN { OFS=" :-( "}; {print $0}'        
1 2 3 4

#Desired result, undesired syntax
[kbrandt@glade: ~] echo "1 2 3 4" | gawk 'BEGIN { OFS=" :-) "}; {print $1,$2,$3,$4}'
1 :-) 2 :-) 3 :-) 4

标签: awk gawk
2条回答
一夜七次
2楼-- · 2019-01-22 13:28

This is a variation on the first style:

echo "1 2 3 4" | gawk 'BEGIN { OFS=" :-( "}; {$1=$1; print $0}'

Results:

1 :-( 2 :-( 3 :-( 4

Explanation:

the $1=$1 is to rebuild the record, using the current OFS (you can also see http://www.gnu.org/software/gawk/manual/gawk.html#Changing-Fields)

Update:

(suggested by @EdMorton and @steve) This is a briefer, equivalent version of the awk command, that sets OFS in the command line, and takes advantage of print $0 as the default action:

awk -v OFS=" :-( " '{$1=$1}1'
查看更多
ら.Afraid
3楼-- · 2019-01-22 13:46

Sed equivalent:

$ echo "1 2 3 4" | sed 's/ /:-)/g'

Here's another option with awk:

$ echo "1 2 3 4" | awk '{ gsub(/\s/, ":-)")}1' 
查看更多
登录 后发表回答