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

[文本处理] 批处理如何根据另一个文本的正则匹配删除匹配到的行。

[复制链接]
发表于 2023-1-21 10:05:06 | 显示全部楼层 |阅读模式
本帖最后由 每天几分 于 2023-1-22 10:28 编辑

文本1
没有 hfhr
没有 hfy
没有 hfhyy
没有 hfhhggj
没有 hfeq
一个 iua
一个 iuui
一个 iuug
一个 iuuy
一个 iuab
放大 fede
放大 fedd
放大 fedd
放大 feddy
两旁        llpe
路两旁        llpee


文本2
^没有 hfh.*
^一个 iuu.*
^两旁        llpe.*


实现文本3
没有 hfy
没有 hfeq
一个 iua
一个 iuab
放大 fede
放大 fedd
放大 fedd
放大 feddy
路两旁        llpee


就是说
文本1中若存在文本2所能匹配的行,则全删除。

【没有 hfh.*】 能匹配 【没有 hfh加任何字母】的行,但不要匹配【没有 hfy】、【没有 hfeq】的行。
要注意的如:
【两旁        llpe.*】不要匹配【路两旁        llpee】这种。
发表于 2023-1-21 10:32:40 | 显示全部楼层
  1. findstr /ivg:文本2.txt 文本1.txt>文本3.txt
复制代码

评分

参与人数 1技术 +1 收起 理由
每天几分 + 1 多谢,这个可以用

查看全部评分

 楼主| 发表于 2023-1-21 10:55:59 | 显示全部楼层
100多万行,bat有点慢,gawk能实现吗?
发表于 2023-1-23 17:22:31 | 显示全部楼层
PowerShell
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-19 05:23 , Processed in 0.017690 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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