免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4728 | 回复: 12

[文本处理] awk替换操作gsub遇到变量时处理,报错,求解决? [复制链接]

论坛徽章:
0
发表于 2016-06-27 16:33 |显示全部楼层
代码如下所示:

aaa="Novartis AG"

bbb="pfizer"

sed -n '2p' Data.txt | awk -F\\t "gsub(/$aaa/, \"$aaa; $bbb\", $5) {print $0}"

awk: gsub(/Novartis AG/, "Novartis AG; pfizer", ) {print -bash}

awk:                                            ^ syntax error

awk: fatal: 0 is invalid as number of arguments for gsub

Data.txt没问题,是以Tab键分隔的,上述报错,问题是出在哪里呢?求解答,感激不尽!

论坛徽章:
28
15-16赛季CBA联赛之八一
日期:2016-02-22 19:10:4215-16赛季CBA联赛之深圳
日期:2016-12-01 10:34:0415-16赛季CBA联赛之新疆
日期:2016-12-07 10:24:2915-16赛季CBA联赛之同曦
日期:2016-12-15 12:06:43CU十四周年纪念徽章
日期:2016-12-18 13:03:4415-16赛季CBA联赛之吉林
日期:2017-01-03 15:52:2515-16赛季CBA联赛之辽宁
日期:2017-01-04 14:58:2415-16赛季CBA联赛之辽宁
日期:2017-01-15 09:42:512016科比退役纪念章
日期:2017-02-06 17:21:50黑曼巴
日期:2017-02-10 15:46:1215-16赛季CBA联赛之上海
日期:2017-03-18 10:14:5415-16赛季CBA联赛之青岛
日期:2017-03-18 22:00:44
发表于 2016-06-27 16:37 |显示全部楼层
本帖最后由 moperyblue 于 2016-06-27 16:38 编辑

第五个域($5)的数据有问题?

论坛徽章:
0
发表于 2016-06-27 16:47 |显示全部楼层
ceritinib      Novartis AG       "ALK inhibitor (oral, cancer), Novartis; LDK-378; Zykadia; ceritinib"      Launched      Novartis AG回复 2# moperyblue

原始如下:(第5域没问题啊,匹配Novartis AG)

data

data


   

论坛徽章:
28
15-16赛季CBA联赛之八一
日期:2016-02-22 19:10:4215-16赛季CBA联赛之深圳
日期:2016-12-01 10:34:0415-16赛季CBA联赛之新疆
日期:2016-12-07 10:24:2915-16赛季CBA联赛之同曦
日期:2016-12-15 12:06:43CU十四周年纪念徽章
日期:2016-12-18 13:03:4415-16赛季CBA联赛之吉林
日期:2017-01-03 15:52:2515-16赛季CBA联赛之辽宁
日期:2017-01-04 14:58:2415-16赛季CBA联赛之辽宁
日期:2017-01-15 09:42:512016科比退役纪念章
日期:2017-02-06 17:21:50黑曼巴
日期:2017-02-10 15:46:1215-16赛季CBA联赛之上海
日期:2017-03-18 10:14:5415-16赛季CBA联赛之青岛
日期:2017-03-18 22:00:44
发表于 2016-06-27 16:54 |显示全部楼层
你单独打印第五个域($5)看看有没异常数据
sed -n '2p' Data.txt | awk -F\\t '{print $5}'|sort -u

求职 : 技术支持/维
论坛徽章:
0
发表于 2016-06-27 16:58 |显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
发表于 2016-06-27 17:04 |显示全部楼层
谢谢,按照你的代码,我这边正常显示Novartis AG的回复 4# moperyblue


   

论坛徽章:
0
发表于 2016-06-27 17:05 |显示全部楼层
所以,$5域没问题,就不知道报错是咋回事了。回复 4# moperyblue


   

论坛徽章:
5
金牛座
日期:2013-10-14 14:40:422015年亚洲杯之伊朗
日期:2015-03-26 10:37:012015亚冠之浦和红钻
日期:2015-10-12 17:47:4115-16赛季CBA联赛之山东
日期:2016-01-20 16:43:1215-16赛季CBA联赛之辽宁
日期:2016-03-29 16:43:59
发表于 2016-06-27 17:14 |显示全部楼层
本帖最后由 itfly3 于 2016-06-27 17:15 编辑

回复 7# chinaunixfan2

echo 'ceritinib      Novartis AG       "ALK inhibitor (oral, cancer), Novartis; LDK-378; Zykadia; ceritinib"      Launched      Novartis AG'|awk -F'    ' "/$aaa/{gsub(/$aaa/,\"$bbb\",\$5)}1"
ceritinib   Novartis AG    "ALK inhibitor (oral, cancer), Novartis; LDK-378; Zykadia; ceritinib"   Launched   pfizer

$5报错是因为,它把这个当成shell的变量了,而不是awk的域了

   

论坛徽章:
0
发表于 2016-06-27 17:16 |显示全部楼层
非常感谢,你对gsub变量的处理是正确的,但我这边又有新的问题,替换后有重复现象,如图所示

cf

cf
回复 5# 99超人


   

论坛徽章:
0
发表于 2016-06-27 17:18 |显示全部楼层

222

222
回复 9# chinaunixfan2


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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP