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

[其他] 【已解决】BAT:如何合并同类项后,再批量替换

[复制链接]
发表于 2023-8-31 11:33:15 | 显示全部楼层 |阅读模式
本帖最后由 思想之翼 于 2023-8-31 21:00 编辑

1.txt 记录数据如下,"=" 左侧数据不重复,"=" 右侧字符有重复:
000=书
001=生
002=书
003=生
004=气

2.txt 记录数据,有重复:





【问题】
合并 1.txt "=" 右侧的同类项
000 002=书
001 003=生
004=气
然后,批量替换 2.txt 的内容

2.txt 替换后的结果为:
000 002
001 003
000 002
001 003

评分

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

查看全部评分

发表于 2023-8-31 12:14:50 | 显示全部楼层
回复 1# 思想之翼


test-1.bat
  1. @echo off
  2. cd /d "%~dp0"
  3. setlocal enabledelayedexpansion
  4. for /f "tokens=1-2 delims==" %%i in ('findstr /i /g:2.txt 1.txt') do (
  5.     if not defined _%%j (
  6.         set "_%%j=%%i"
  7.     ) else (
  8.         set "_%%j=!_%%j! %%i"
  9.     )
  10. )
  11. (for /f "tokens=1-2 delims==" %%i in ('type 1.txt') do (
  12.     echo,!_%%j!
  13. ))>"2.new.txt"
  14. endlocal
复制代码
test-2.bat
  1. @echo off
  2. cd /d "%~dp0"
  3. setlocal enabledelayedexpansion
  4. for /f "tokens=1-2 delims==" %%i in ('findstr /i /g:2.txt 1.txt') do (
  5.     if not defined _%%j (
  6.         set "_%%j=%%i"
  7.     ) else (
  8.         set "_%%j=!_%%j! %%i"
  9.     )
  10. )
  11. (for /f "delims=" %%i in ('type 2.txt') do (
  12.     echo,!_%%i!
  13. ))>"2.new.txt"
  14. endlocal
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢分享

查看全部评分

发表于 2023-8-31 13:19:26 | 显示全部楼层
楼主要求“批量替换 2.txt 的内容”,第2个for中是否应当以2.txt作为替换目标。
 楼主| 发表于 2023-8-31 13:51:24 | 显示全部楼层
回复 3# qixiaobin0715
是的,感谢关注。
发表于 2023-8-31 16:03:46 | 显示全部楼层
啊,都不说怎么合并和怎么替换
看了老半天替换结果才看懂(也不知道对不对)
发表于 2023-8-31 16:08:19 | 显示全部楼层
本帖最后由 qixiaobin0715 于 2023-8-31 16:10 编辑

回复 2# Batcher
test-2.bat 12行笔误:!_%%j!——>!_%%i!
发表于 2023-9-1 09:39:18 | 显示全部楼层
回复 1# 思想之翼

1.直接出结果(如有不匹配数据则输出空行):

  1. gawk -F"[ =]+" "NR==FNR{a[$2]=a[$2]?a[$2]" "$1:""$1}NR>FNR{print a[$0]}" 1.txt 2.txt>3.txt
复制代码
2.剔除不匹配的数据

  1. gawk -F"[ =]+" "NR==FNR{a[$2]=a[$2]?a[$2]" "$1:""$1}NR>FNR{if($0 in a)print a[$0]}" 1.txt 2.txt>3.txt
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢分享

查看全部评分

发表于 2023-9-1 11:43:05 | 显示全部楼层

纯P版还可以更简化一些...

  1. @echo off &setlocal enabledelayedexpansion
  2. for /f "tokens=1-2 delims==" %%1 in (1.txt) do (
  3.         if defined _%%2 (set "_%%2=!_%%2! %%1") else (set "_%%2=%%1")
  4. )
  5. for /f %%F in (2.txt) do if defined _%%F (echo,!_%%F!)
  6. endlocal &pause &exit/b
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢分享

查看全部评分

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

本版积分规则

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

GMT+8, 2026-3-18 14:15 , Processed in 0.022501 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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