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

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

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

评分人数

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

回复 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

评分人数

我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

楼主要求“批量替换 2.txt 的内容”,第2个for中是否应当以2.txt作为替换目标。

TOP

回复 3# qixiaobin0715
是的,感谢关注。

TOP

啊,都不说怎么合并和怎么替换
看了老半天替换结果才看懂(也不知道对不对)

TOP

本帖最后由 qixiaobin0715 于 2023-8-31 16:10 编辑

回复 2# Batcher
test-2.bat 12行笔误:!_%%j!——>!_%%i!

TOP

回复 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

评分人数

TOP


纯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

评分人数

TOP

返回列表