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

[文本处理] [已解决]批处理findstr命令如何删除符合两个条件或以上的行?

例如:1.txt内容如下

1111 2222 3333
2222 3333 4444
3333 4444 5555

怎么才能用findstr删掉含 2222 以及 4444的行呢?

findstr /v "2222 4444" "1.txt"不对!
1

评分人数

    • Batcher: 感谢给帖子标题标注[已解决]字样PB + 2
悲杯,没有可用的签名。。

  1. sed "/2222/{/4444/d}" a.txt
复制代码

TOP

回复 6# CrLf


    呵呵,写代码难免啊,谢谢版主。解决就好了!
悲杯,没有可用的签名。。

TOP

晕,我想到哪去了...

TOP

回复 3# weichenxiehou


    嗯,谢谢大大,解决了。
悲杯,没有可用的签名。。

TOP

回复 2# CrLf


    版主这样也无效,前面选过滤了 2222 的行,再过滤其中含4444的行。

  第一步就把所有含2222的行给丢掉了,也就误杀了。
悲杯,没有可用的签名。。

TOP

回复 2# CrLf
好像不用管道可以哦,
  1. findstr /v "2222.*4444 4444.*2222" test.txt
复制代码
1

评分人数

    • CrLf: 谢谢指正技术 + 1
看得多说得多,远比不上写得多。

TOP

单个 for 无法实现“and”,所以只好用管道了,效率虽低,但是也只好这样
  1. findstr /v "2222" 1.txt|findstr /v "4444"
复制代码

TOP

返回列表