免费注册 查看新帖 |

Chinaunix

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

[文本处理] 用awk把列变行遇到的一个问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-07-30 14:32 |只看该作者 |倒序浏览
本帖最后由 HSRLJYHCY 于 2014-07-30 14:35 编辑

lxdb0294::/opt/app/oracle/admin#cat mt.txt
3113
4159
4069
24436

我想把它变成 3113,4159,4069,24436

用下面的办法,但后面多出一个主机和目录提示符
lxdb0294::/opt/app/oracle/admin#cat mt.txt|awk -v ORS="," '1'
3113,4159,4069,24436,lxdb0294::/opt/app/oracle/admin#
                                  ^^^^^^^^^^^^^^^^^^^^^^ <== 这里

如何写才能实现只要3113,4159,4069,2443,不要后面的主机和目录提示符


论坛徽章:
5
未羊
日期:2014-08-04 16:15:21天秤座
日期:2014-08-13 13:52:372015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:112015亚冠之浦和红钻
日期:2015-06-29 15:30:48
2 [报告]
发表于 2014-07-30 14:50 |只看该作者
  1. tr "\n" "," < mt.txt
复制代码

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
3 [报告]
发表于 2014-07-30 14:54 |只看该作者
  1. sed ':1;N;$!b1;s/\n/,/g'
复制代码

论坛徽章:
0
4 [报告]
发表于 2014-07-30 15:01 |只看该作者
回复 2# dn833


   不行

ssdb0220:BRM1AP1:/opt/app/oracle/admin#cat all_process.txt
1262
1203
29096
8121
12726
5504
29130
29124
29002
29128
29122
29126
29116
5494
29132

ssdb0220:BRM1AP1:/opt/app/oracle/admin#tr "\n" "," < all_process.txt
1262,1203,29096,8121,12726,5504,29130,29124,29002,29128,29122,29126,29116,5494,29132,ssdb0220:BRM1AP1:/opt/app/oracle/admin#

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
5 [报告]
发表于 2014-07-30 15:01 |只看该作者
本帖最后由 jason680 于 2014-07-30 15:08 编辑

回复 1# HSRLJYHCY

$ awk '{printf P$1;P=","}END{print""}' mt.txt
3113,4159,4069,24436
$
   

论坛徽章:
60
20周年集字徽章-20	
日期:2020-10-28 14:04:3015-16赛季CBA联赛之北京
日期:2016-07-06 15:42:0715-16赛季CBA联赛之同曦
日期:2016-06-12 10:38:0915-16赛季CBA联赛之佛山
日期:2016-05-27 11:54:56黄金圣斗士
日期:2015-12-02 11:44:35白银圣斗士
日期:2015-11-25 14:32:43白银圣斗士
日期:2015-11-23 12:53:352015亚冠之布里斯班狮吼
日期:2015-10-21 16:55:482015亚冠之首尔
日期:2015-09-01 16:46:052015亚冠之德黑兰石油
日期:2015-08-31 11:39:192015亚冠之萨济拖拉机
日期:2015-08-28 21:06:5315-16赛季CBA联赛之广东
日期:2016-07-12 14:58:53
6 [报告]
发表于 2014-07-30 15:05 |只看该作者
  1. paste -s d, mt.txt
复制代码

论坛徽章:
0
7 [报告]
发表于 2014-07-30 15:05 |只看该作者
回复 3# yestreenstars

在Linux系统可以,但在Solaris遇到下面的问题

ssdb0220:BRM1AP1:/opt/app/oracle/admin#cat all_process.txt |sed ':1;N;$!b1;s/\n/,/g'
Label too long: :1;N;$!b1;s/\n/,/g
   

论坛徽章:
0
8 [报告]
发表于 2014-07-30 15:11 |只看该作者
回复 5# jason680

这位兄弟,谢谢了,你的代码在Linux和Solaris通过


   

论坛徽章:
39
辰龙
日期:2013-08-21 15:45:192015亚冠之广州富力
日期:2015-05-12 16:34:52亥猪
日期:2015-03-03 17:22:00申猴
日期:2015-03-03 17:21:37未羊
日期:2014-10-10 13:45:41戌狗
日期:2014-06-17 09:53:29巨蟹座
日期:2014-06-12 23:17:17双鱼座
日期:2014-06-10 12:42:44寅虎
日期:2014-06-09 12:52:172015亚冠之卡尔希纳萨夫
日期:2015-05-24 15:24:35黄金圣斗士
日期:2015-12-02 17:25:0815-16赛季CBA联赛之吉林
日期:2017-06-24 16:43:52
9 [报告]
发表于 2014-07-30 15:23 |只看该作者
  1. awk '{a=a!=""?a","$0:$0}END{print a}'  urfile
复制代码

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
10 [报告]
发表于 2014-07-30 15:34 |只看该作者
楼主的问题其实是 PS1 设置有问题, 在 PS1 的开头应该有一个 "\n",可能楼主的没有. 结果 由于 awk没有在最后打一个 \n, 结果, 就把 输出结束后 的 PS1 给打在输出后面.

其实, 只要把结果输出到文件, 问题就解决了. 唯一的问题是最后一个 "," 这个需要单独处理一下.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP