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

[文本处理] [已解决]bat或第三方命令行如何实现如下功能?

本帖最后由 shootman2 于 2015-4-15 10:12 编辑

假如有一个文本123.txt,内容为

123 abcdef
456 qweqweqwe
789 asdfghjkl

执行一个命令行,列出其中的以 123 789 开头的行!
我想用gawk来实现,结果没有成功,求助大神实现!
1

评分人数

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

  1. @echo off
  2. gawk "/^(123|789)/" "test.txt"
  3. pause
复制代码
1

评分人数

TOP

  1. @echo off
  2. setlocal enabledelayedexpansion
  3. for /f "delims=" %%a in (test.txt) do (
  4. set "str=%%a"
  5. if "!str:~,3!" equ "123" (echo,%%a) else if "!str:~,3!" equ "789" (echo,%%a)
  6. )
  7. pause
复制代码

TOP

  1. @echo off
  2. sed -n "/^123\|^789/p" "test.txt"
  3. pause
复制代码

TOP

回复 2# pcl_test


    嗯!这个好,太棒了!!!问题解决了!

TOP

  1. grep -E "^123|^789" 1.txt > 2.txt
复制代码
Talk is cheap. Show me the code.
没事不要瞎扯淡,有能耐就把代码贴出来给我看。

TOP

  1. sed "/^123\|^789/!d" 1.txt > 2.txt
复制代码
Talk is cheap. Show me the code.
没事不要瞎扯淡,有能耐就把代码贴出来给我看。

TOP

  1. findstr "^123 ^789" 1.txt > 2.txt
复制代码
Talk is cheap. Show me the code.
没事不要瞎扯淡,有能耐就把代码贴出来给我看。

TOP

返回列表