免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1836 | 回复: 5
打印 上一主题 下一主题

[文本处理] 局部排序求助 [复制链接]

论坛徽章:
18
辰龙
日期:2014-05-21 21:01:4115-16赛季CBA联赛之深圳
日期:2016-12-23 13:51:3815-16赛季CBA联赛之北控
日期:2016-11-28 18:26:3815-16赛季CBA联赛之佛山
日期:2016-11-03 11:18:5815-16赛季CBA联赛之辽宁
日期:2016-07-10 16:09:4115-16赛季CBA联赛之江苏
日期:2016-02-20 23:09:202015亚冠之塔什干棉农
日期:2015-08-17 19:49:492015年亚洲杯之日本
日期:2015-04-30 01:24:342015年亚洲杯之约旦
日期:2015-04-01 00:37:182015年亚洲杯之沙特阿拉伯
日期:2015-03-02 15:55:40处女座
日期:2014-05-25 10:34:0020周年集字徽章-年
日期:2023-04-23 11:17:52
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2018-05-13 22:29 |只看该作者 |倒序浏览
大家好!
我有一个问题向大家请教。
有以下一个文本,希望对连续的三行中有THRESHOLD、CRITICAL和CURRENT的行进行排序。
SERVER:         135.240.144.16
USER:           1ls
THRESHOLD:      100 G
CRITICAL:       50 G
CURRENT:        70.30 G (75488632832 Bytes) available
-----------------------------------------------------------------------------
SERVER:         135.240.146.254
USER:           1ls
THRESHOLD:      100 G
CRITICAL:       50 G
CURRENT:        426.59 G (458046586880 Bytes) available
-----------------------------------------------------------------------------
希望得到的结果是:
SERVER:         135.240.144.16
USER:           1ls
THRESHOLD:      100 G
CURRENT:        70.30 G (75488632832 Bytes) available
CRITICAL:       50 G
-----------------------------------------------------------------------------
SERVER:         135.240.146.254
USER:           1ls
CURRENT:        426.59 G (458046586880 Bytes) available
THRESHOLD:      100 G
CRITICAL:       50 G
-----------------------------------------------------------------------------
请问awk命令应该如何写呢?
谢谢大家!


论坛徽章:
25
程序设计版块每日发帖之星
日期:2016-05-03 06:20:0015-16赛季CBA联赛之八一
日期:2018-07-05 10:34:09黑曼巴
日期:2018-07-06 15:19:5015-16赛季CBA联赛之佛山
日期:2018-08-03 13:19:3315-16赛季CBA联赛之山西
日期:2018-08-07 19:46:2315-16赛季CBA联赛之广夏
日期:2018-08-08 19:31:5015-16赛季CBA联赛之青岛
日期:2018-11-26 15:21:5015-16赛季CBA联赛之上海
日期:2018-12-11 09:45:3219周年集字徽章-年
日期:2020-04-18 23:54:5215-16赛季CBA联赛之深圳
日期:2020-04-19 21:40:19黑曼巴
日期:2022-04-03 17:55:1315-16赛季CBA联赛之八一
日期:2018-07-03 16:56:46
2 [报告]
发表于 2018-05-14 09:41 |只看该作者
回复 1# bikkuri


<<<awk4.0+
  1. awk '/^THRESHOLD/||/^CRITICAL/||/^CURRENT/{a[$2]=$0;next}/^-/{PROCINFO["sorted_in"]="@ind_num_desc";for(i in a){print a[i]};delete a}1' file
复制代码

论坛徽章:
18
辰龙
日期:2014-05-21 21:01:4115-16赛季CBA联赛之深圳
日期:2016-12-23 13:51:3815-16赛季CBA联赛之北控
日期:2016-11-28 18:26:3815-16赛季CBA联赛之佛山
日期:2016-11-03 11:18:5815-16赛季CBA联赛之辽宁
日期:2016-07-10 16:09:4115-16赛季CBA联赛之江苏
日期:2016-02-20 23:09:202015亚冠之塔什干棉农
日期:2015-08-17 19:49:492015年亚洲杯之日本
日期:2015-04-30 01:24:342015年亚洲杯之约旦
日期:2015-04-01 00:37:182015年亚洲杯之沙特阿拉伯
日期:2015-03-02 15:55:40处女座
日期:2014-05-25 10:34:0020周年集字徽章-年
日期:2023-04-23 11:17:52
3 [报告]
发表于 2018-05-14 15:00 |只看该作者
回复 2# wh7211

谢谢您的帮助。可是我的awk版本比较低,是3.1.7。
┌─[Mon May 14 14:56:50 CST 2018]
└─[root@apaciprtac:/tmp]# awk '/^THRESHOLD/||/^CRITICAL/||/^CURRENT/{a[$2]=$0;next}/^-/{PROCINFO["sorted_in"]="@ind_num_desc";for(i in a){print a};delete a}1' file
SERVER:         135.240.144.16
USER:           1ls
THRESHOLD:      100 G
CURRENT:        70.30 G (75488632832 Bytes) available
CRITICAL:       50 G
-----------------------------------------------------------------------------
SERVER:         135.240.146.254
USER:           1ls
THRESHOLD:      100 G
CURRENT:        426.59 G (458046586880 Bytes) available
CRITICAL:       50 G
-----------------------------------------------------------------------------
┌─[Mon May 14 14:56:57 CST 2018]
└─[root@apaciprtac:/tmp]# awk --version
GNU Awk 3.1.7
Copyright (C) 1989, 1991-2009 Free Software Foundation.

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program. If not, see http://www.gnu.org/licenses/.
┌─[Mon May 14 14:57:04 CST 2018]
└─[root@apaciprtac:/tmp]#

在这个awk版本下您的命令不能得到正确的结果。
请问应该如何修改才能在awk 3.1.7下得到正确的结果呢?
谢谢!

论坛徽章:
30
申猴
日期:2014-04-10 09:43:532015年亚洲杯纪念徽章
日期:2015-03-20 14:40:232015亚冠之阿尔纳斯尔
日期:2015-06-02 18:59:042015亚冠之阿尔希拉尔
日期:2015-06-30 15:22:572015亚冠之大阪钢巴
日期:2015-07-20 10:44:332015亚冠之阿尔纳斯尔
日期:2015-10-28 14:57:5215-16赛季CBA联赛之新疆
日期:2015-12-25 10:18:45黑曼巴
日期:2016-06-26 21:39:5315-16赛季CBA联赛之山西
日期:2016-07-25 21:54:2715-16赛季CBA联赛之北京
日期:2016-10-27 12:07:2315-16赛季CBA联赛之八一
日期:2017-07-07 16:39:0915-16赛季CBA联赛之吉林
日期:2017-09-04 12:14:43
4 [报告]
发表于 2018-05-15 14:12 |只看该作者
回复 1# bikkuri


在数值没有重复值的情况下!

awk '/THRESHOLD|CRITICAL|CURRENT/{a[$1]=$2;b[$2]=$0;next}!/^-/{d[++t]=$0}/^-/{for(j=1;j<=t;j++) print d[j];for(i=asort(a,c);i>0;i--) print b[c];print $0;t=0}' file


论坛徽章:
25
程序设计版块每日发帖之星
日期:2016-05-03 06:20:0015-16赛季CBA联赛之八一
日期:2018-07-05 10:34:09黑曼巴
日期:2018-07-06 15:19:5015-16赛季CBA联赛之佛山
日期:2018-08-03 13:19:3315-16赛季CBA联赛之山西
日期:2018-08-07 19:46:2315-16赛季CBA联赛之广夏
日期:2018-08-08 19:31:5015-16赛季CBA联赛之青岛
日期:2018-11-26 15:21:5015-16赛季CBA联赛之上海
日期:2018-12-11 09:45:3219周年集字徽章-年
日期:2020-04-18 23:54:5215-16赛季CBA联赛之深圳
日期:2020-04-19 21:40:19黑曼巴
日期:2022-04-03 17:55:1315-16赛季CBA联赛之八一
日期:2018-07-03 16:56:46
5 [报告]
发表于 2018-05-15 14:53 |只看该作者
回复 3# bikkuri


  1. awk '/^THRESHOLD/||/^CRITICAL/||/^CURRENT/{a[$0]=$2;b[$2]=$0;next}/^-/{d=asort(a,c);for(i=d;i>=1;i--){print b[c[i]]};delete a}1' file
复制代码

论坛徽章:
18
辰龙
日期:2014-05-21 21:01:4115-16赛季CBA联赛之深圳
日期:2016-12-23 13:51:3815-16赛季CBA联赛之北控
日期:2016-11-28 18:26:3815-16赛季CBA联赛之佛山
日期:2016-11-03 11:18:5815-16赛季CBA联赛之辽宁
日期:2016-07-10 16:09:4115-16赛季CBA联赛之江苏
日期:2016-02-20 23:09:202015亚冠之塔什干棉农
日期:2015-08-17 19:49:492015年亚洲杯之日本
日期:2015-04-30 01:24:342015年亚洲杯之约旦
日期:2015-04-01 00:37:182015年亚洲杯之沙特阿拉伯
日期:2015-03-02 15:55:40处女座
日期:2014-05-25 10:34:0020周年集字徽章-年
日期:2023-04-23 11:17:52
6 [报告]
发表于 2018-05-15 17:50 |只看该作者
谢谢两位的帮助。
貌似wh7211君的命令可以得到正确结果,而zxy877298415君的命令出错了。
┌─[Tue May 15 17:47:35 CST 2018]
└─[root@apaciprtac:/tmp]# awk '/^THRESHOLD/||/^CRITICAL/||/^CURRENT/{a[$0]=$2;b[$2]=$0;next}/^-/{d=asort(a,c);for(i=d;i>=1;i--){print b[c[i]]};delete a}1' file
SERVER:         135.240.144.16
USER:           1ls
THRESHOLD:      100 G
CURRENT:        70.30 G (75488632832 Bytes) available
CRITICAL:       50 G
-----------------------------------------------------------------------------
SERVER:         135.240.146.254
USER:           1ls
CURRENT:        426.59 G (458046586880 Bytes) available
THRESHOLD:      100 G
CRITICAL:       50 G
-----------------------------------------------------------------------------
┌─[Tue May 15 17:47:40 CST 2018]
└─[root@apaciprtac:/tmp]# awk '/THRESHOLD|CRITICAL|CURRENT/{a[$1]=$2;b[$2]=$0;next}!/^-/{d[++t]=$0}/^-/{for(j=1;j<=t;j++) print d[j];for(i=asort(a,c);i>0;i--) print b[c];print $0;t=0}' file
SERVER:         135.240.144.16
USER:           1ls
awk: (FILENAME=file FNR=6) fatal: attempt to use array `c' in a scalar context
┌─[Tue May 15 17:48:06 CST 2018]
└─[root@apaciprtac:/tmp]#


您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP