使用awk对文档中特定字段的排序
----------------------------------------------------
我现在想对其按Salary从高到低进行排序,这时我们就会想到用数据库进行排序,这样的话要把这些数据导入数据库,如Mysql, sqlite等,但当我们手头没有这些数据库时,其实我们可以用一个叫做awk的程序设计语言来处理,它的优点是非常适合处理结构化数据。
----------------------------------------------------
1. 问题定义
现在要对如下文档按特定字段排序,lemo@debian:~/Testspace/awk$ cat file
Name Sex Salary
Lemo man 4000
Jok woman 3000
Job man 6000
Petty man 9000
我现在想对其按Salary从高到低进行排序,这时我们就会想到用数据库进行排序,这样的话要把这些数据导入数据库,如Mysql, sqlite等,但当我们手头没有这些数据库时,其实我们可以用一个叫做awk的程序设计语言来处理,它的优点是非常适合处理结构化数据。
2. 代码分析
# @auth lemo.lu
# @data 2011.11.16
# use to sort the record with specific field
# BEGIN BLOCK
BEGIN{
print "BEGIN SORT"
}
##############################################
# NR - number of records , start from 1
# NF - number of fields
# $0 - the whole line
# $1,$2 - the first column as $1, the second column as $2
##############################################
NR==1 { # if number of record equals to 1
fo