免费注册 查看新帖 |

ChinaUnix.net

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 705 | 回复: 3

[文本处理] 插入匹配数字 [复制链接]

论坛徽章:
0
发表于 2019-02-27 11:54 |显示全部楼层
本帖最后由 sks108 于 2019-02-27 12:17 编辑

遇到个问题 手动修改太慢了,想批量执行对应上file1的内容 有没有大佬指教下
file1
zhang=100
li=200
wang=300


zhang.txt
id=x
sc=x
num=


li.txt
id=x
sc=x
num=

结果要求 zhang.txt 和 li.txt的第三列 “num=” 后面匹配file1的第二列等于后的数字   
zhang.txt
id=x
sc=x
num=100

li.txt
id=x
sc=x
num=200

我已知的单独添加方法  sed -i -e '/匹配指定字符/{n;n;s|$|要添加的内容|}'

论坛徽章:
0
发表于 2019-02-27 14:47 |显示全部楼层
自顶一下··

论坛徽章:
0
发表于 2019-02-27 16:47 |显示全部楼层
本帖最后由 csccyab 于 2019-02-27 16:48 编辑

$ cat zhang.txt
id=x
sc=x
num=

$ cat li.txt
id=x
sc=x
num=

$ awk -F'=' 'FNR==NR{a[$1]=$2; next} FNR==1{print FILENAME} {sub(/\.txt/,"",FILENAME); if ($0~/num/)$2=a[FILENAME]; print $1FS$2}' file1 zhang.txt li.txt
id=x
sc=x
num=100
li.txt
id=x
sc=x
num=200


论坛徽章:
0
发表于 2019-02-28 09:43 |显示全部楼层
厉害厉害,感谢大神
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

基于案例的 SQL 优化实战训练营

讲师:中电福富特级专家梁敬彬,参与本次课程培训,你将收获:
1. 能编写出较为高效的 SQL;
2. 能解决70%以上的数据库常见优化问题;
3. 能得到老师提供的高效的相关工具和解决方案;
4. 能举一反三,收获不仅仅是 SQL 优化。
现在购票享受8.8折优惠!
----------------------------------------
优惠时间:2019年3月20日前

大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP