免费注册 查看新帖 |

Chinaunix

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

[文本处理] 给文本添加列 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-06-05 14:01 |只看该作者 |倒序浏览
本帖最后由 netocool 于 2013-06-05 14:21 编辑

这是我的文本内容:
  1. 100   B1
  2. 101   B2
  3. 102   B50
  4. 103   B8
  5. 104   B60
  6. 105   BE1
复制代码
我想加多一列,B1=66, B2=67, B10=70, B50=70, B8=69, B60=74, BE1=8
需要的效果如下:
  1. 100   B1     66
  2. 101   B2     67
  3. 102   B50   70
  4. 103   B8   69
  5. 104   B60   74
  6. 105   BE1   8
复制代码
如何实现呢?

论坛徽章:
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
2 [报告]
发表于 2013-06-05 14:16 |只看该作者
本帖最后由 jason680 于 2013-06-05 14:17 编辑

回复 1# netocool

How about this
$ awk -vs=66 '{NF++;$NF=s;s++;print $0}' FILE

or combine all action together...
$ awk -vs=66 '{$(++NF)=s++}1' FILE
100 B1 66
101 B2 67
102 B10 68
103 B50 69
104 B60 70

   

论坛徽章:
0
3 [报告]
发表于 2013-06-05 14:19 |只看该作者
回复 2# jason680


    不好意思,我的文件第二列的排序是没有递增或者递减的规律的

论坛徽章:
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
4 [报告]
发表于 2013-06-05 14:57 |只看该作者
回复 3# netocool

1. set the item and value in 'set' file
Note: set more items and value by yourself

$ cat set
B1  66
BE1  8

$ cat FILE
100   B1
105   BE1

$ awk 'FNR==NR{a[$1]=$2;next}{print $0,a[$2]}' set FILE
100   B1 66
105   BE1 8


2. set the item and value in your code

$ awk 'BEGIN{a["B1"]=66;a["BE1"]=8}{print $0,a[$2]}' FILE
100   B1 66
105   BE1 8

   

论坛徽章:
0
5 [报告]
发表于 2013-06-05 15:16 |只看该作者
thank you very much.

论坛徽章:
0
6 [报告]
发表于 2013-06-05 19:05 |只看该作者
  1. /opt # cat file1
  2. 100   B1
  3. 101   B2
  4. 102   B5
  5. 0103  B8
  6. 104   B60
  7. 105   BE1
  8. /opt # cat file2
  9. B1=66, B2=67, B10=70, B50=70, B8=69, B60=74, BE1=8
  10. /opt # awk 'BEGIN{FS="[ ,]";OFS=" ";FS="[ ,=]+"}NR==FNR{a[$2]=$1;next}{for(i=1;i<=NF;i++){if(a[$i]){print a[$i],$i,$(i+1)}}}' file1 file2
  11. 100 B1 66
  12. 101 B2 67
  13. 0103 B8 69
  14. 104 B60 74
  15. 105 BE1 8
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP