找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 18981|回复: 1

[文本处理] 【已解决】gawk:如何替换无空格且多行多列的字符串

[复制链接]
发表于 2023-10-2 14:31:45 | 显示全部楼层 |阅读模式
本帖最后由 思想之翼 于 2023-10-2 17:45 编辑

字典文件1.txt记录格式为:
203=书
504=生
003=气

替换文件2.txt记录格式为:
203 504 003
203 504

欲替换2.txt文件中的字符串
【解决方案】
  1. gawk -F"[ =]" "NR==FNR{A[$1]=$2;next}{for (i=1;i<=NF;i++) printf(i<NF?"%%s ":"%%s\n",A[$i])}" 1.txt 2.txt >3.txt
复制代码
结果文件3.txt为:
书 生 气
书 生

【问题】若替换文件2.txt字符间无空格分割,gawk代码如何相应修改,恳望指导。
示例
字典文件1.txt记录格式为:
书=203*203*
生=504*504*
气=003*

替换文件2.txt记录格式为:
书生气
书生

结果文件3.txt为:
203*203*504*504*003*
203*203*504*504*

评分

参与人数 1PB +2 收起 理由
Batcher + 2 感谢给帖子标题标注[已解决]字样

查看全部评分

发表于 2023-10-2 17:31:53 | 显示全部楼层
不知行否
1.txt和2.txt编码gbk

  1. gawk -F"=" "NR==FNR{A[$1]=$2;next}{split($0,B,"");c=length(B);for (i=1;i<=c;i++) printf(i<c?"%%s":"%%s\n",A[B[i]])}" 1.txt 2.txt >3.txt
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢,结果正确。

查看全部评分

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

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-18 11:55 , Processed in 0.015576 second(s), 9 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表