[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

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

本帖最后由 思想之翼 于 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*
1

评分人数

    • Batcher: 感谢给帖子标题标注[已解决]字样PB + 2

不知行否
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

评分人数

TOP

返回列表