免费注册 查看新帖 |

ChinaUnix.net

  平台 论坛 博客 文库 频道自动化运维 虚拟化 储存备份 C/C++ PHP MySQL 嵌入式 Linux系统
最近访问板块 发新帖
查看: 1116 | 回复: 6

[文本处理] awk变量赋值 [复制链接]

论坛徽章:
0
发表于 2018-04-17 10:32 |显示全部楼层
有以下文本:
10
20
30
40
想增加两列,第二列为 第一列的值+a,第三列为第一列的值-a,
即  value  value+a  value-a 如下列示例数据,其中对于每行a是一个不同的随机数,保留两位小数
10  10.50  9.50
20  22     18
30  31     29
40  43     37
暂时想法如下:
cat 1 | awk '{printf "%.2f ",rand()*100%3}{print $0,$0+a,$0-a}'
想把printf "%.2f ",rand()*100%3 赋值给a,
cat 1 | awk '{a=printf "%.2f ",rand()*100%3}{print $0,$0+a,$0-a}'
这样写报错,请教大家,谢谢

论坛徽章:
0
发表于 2018-04-17 10:45 |显示全部楼层
当前的想法曲线下:awk分两次来做,第一次生成每行的随机数,第二次可直接调用上一次生成的随机数使用

论坛徽章:
19
程序设计版块每日发帖之星
日期:2015-10-11 06:20:0015-16赛季CBA联赛之浙江
日期:2018-07-14 13:27:4015-16赛季CBA联赛之同曦
日期:2018-04-17 12:43:3415-16赛季CBA联赛之福建
日期:2018-02-09 14:28:3315-16赛季CBA联赛之四川
日期:2017-09-04 12:27:0315-16赛季CBA联赛之青岛
日期:2017-06-26 18:30:0315-16赛季CBA联赛之新疆
日期:2017-04-12 22:55:4715-16赛季CBA联赛之山东
日期:2016-05-28 18:18:5615-16赛季CBA联赛之新疆
日期:2016-05-07 05:05:3215-16赛季CBA联赛之八一
日期:2016-03-14 12:32:06IT运维版块每日发帖之星
日期:2016-02-27 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-31 10:37:36
发表于 2018-04-17 12:41 |显示全部楼层
  1. [root@test-01 ~]# awk 'BEGIN{print rand()*100%3}'     
  2. 2.77875
  3. [root@test-01 ~]# awk 'BEGIN{print rand()*100%3}'
  4. 2.77875
  5. [root@test-01 ~]# awk 'BEGIN{print rand()*100%3}'
  6. 2.77875
  7. [root@test-01 ~]# awk 'BEGIN{print rand()*100%3}'
  8. 2.77875
  9. [root@test-01 ~]# awk 'BEGIN{print rand()*100%3}'
  10. 2.77875
  11. [root@test-01 ~]# awk 'BEGIN{print rand()}'      
  12. 0.237788
  13. [root@test-01 ~]# awk 'BEGIN{print rand()}'
  14. 0.237788
  15. [root@test-01 ~]# awk 'BEGIN{print rand()}'
  16. 0.237788
  17. [root@test-01 ~]# awk 'BEGIN{print rand()}'
  18. 0.237788
  19. [root@test-01 ~]# awk 'BEGIN{print rand()}'
  20. 0.237788
复制代码

论坛徽章:
5
白羊座
日期:2014-10-28 11:23:27水瓶座
日期:2015-01-20 10:19:022015亚冠之柏斯波利斯
日期:2015-07-11 18:17:2015-16赛季CBA联赛之同曦
日期:2015-12-23 12:38:582016猴年福章徽章
日期:2016-02-18 15:30:34
发表于 2018-04-17 12:41 |显示全部楼层
使用 sprintf 来生成格式化字符串

论坛徽章:
0
发表于 2018-04-17 15:17 |显示全部楼层
回复 4# klainogn

thanks

论坛徽章:
130
技术图书徽章
日期: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
发表于 2018-04-17 17:30 |显示全部楼层
回复 1# bamqjurgg


$ awk 'BEGIN{srand()}{a=sprintf("%.2f",rand()*100%3);print $1,$1+a,$1-a}' file
10 11.57 8.43
20 22.82 17.18
30 31.59 28.41
40 42.34 37.66

$ awk 'BEGIN{srand()}{a=sprintf("%.2f",rand()*100%3);print $1,$1+a,$1-a}' file
10 11.04 8.96
20 20.13 19.87
30 32.32 27.68
40 41.61 38.39

论坛徽章:
21
程序设计版块每日发帖之星
日期:2016-05-03 06:20:0015-16赛季CBA联赛之深圳
日期:2018-06-15 14:59:3715-16赛季CBA联赛之八一
日期:2018-07-03 16:56:4615-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-06-08 13:45:2815-16赛季CBA联赛之同曦
日期:2018-06-04 19:42:2015-16赛季CBA联赛之山东
日期:2018-05-30 12:44:59
发表于 2018-04-17 17:45 |显示全部楼层
回复 1# bamqjurgg


  1. awk '{a=sprintf("%.2f",100*rand()%3);print $0,$0+a,$0-a}' 1
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

数据风云,十年变迁
DTCC 第十届中国数据库技术大会已启航!

2019年5月8日~5月10日,由IT168旗下ITPUB企业社区平台主办的第十届中国数据库技术大会(DTCC2019),将在北京隆重召开。大会将邀请百余位行业专家,就热点技术话题进行分享,是广大数据领域从业人士的又一次年度盛会和交流平台。与SACC2018类似,本届大会将采用“3+2”模式:3天传统技术演讲+2天深度主题培训。大会不仅提供超100场的主题演讲,还会提供连续2天的深度课程培训,深化数据领域的项目落地实践方案。
DTCC2019,一场值得期待的数据技术盛会,殷切地希望您报名参与!

活动入口>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP