Board logo

标题: for语句中如果要处理中间的几行,怎么写skip [打印本页]

作者: renrenrenshk     时间: 2007-9-16 19:22    标题: for语句中如果要处理中间的几行,怎么写skip

大家来讨论下这个问题吧,for语句中如果要处理某个命令输出的中间的几行文字请问要如何处理(比如skip=n是跳过开头n行,如果同时还要跳过最后几行呢,那么这个skip该怎么表达。。。。
作者: lxmxn     时间: 2007-9-16 21:38
你可以在处理完了中间的行之后,用一个goto命令跳转到for命令之外。

也可以用 if+for 来处理。
作者: renrenrenshk     时间: 2007-9-16 22:30
请问二楼的那你如何判断具体执行到那个位置跳出 能不能举个具体例子
作者: lxmxn     时间: 2007-9-16 23:21
比如我现在有一个ok.txt文件,内容如下:

  Quote:
1 1  1   1    1
2 2  2   2    2
3 3  3   3    3
4 4  4   4    4
5 5  5   5    5
6 6  6   6    6
7 7  7   7    7
8 8  8   8    8
9 9  9   9    9
10 10  10   10    10
11 11  11   11    11

我现在只显示第三到第七行的内容,可以用下面这个:
@echo off
        rem 处理第三到第七行
        for /f "skip=2 tokens=1* delims=:" %%a in ('findstr /n .* ok.txt') do (
                echo 第%%a行 -- %%b
                if -%%a==-7 goto :end
        )
:end
echo the end
pause

作者: renrenrenshk     时间: 2007-9-17 09:01
楼上的例子有点繁 特改如下:
-----------------------------------------------------------------------------------------------
@echo off
        rem 处理第三到第七行
        for /f "skip=2 tokens=1* delims=:" %%a in ('findstr /n . ok.txt') do (
                echo 第%%a行 -- %%b
                if %%a==7 goto :end
        )
:end
echo the end
pause
-------------------------------------------------------------------------------------------------

[ Last edited by renrenrenshk on 2007-9-17 at 09:04 AM ]
作者: renrenrenshk     时间: 2007-9-17 09:12
楼上的方法还不是非常灵活,比如dir命令的输出结果的行数是经常变的(随着文件夹的不同而不同),只有头尾几行是不变的,如果要处理除了那些不变 的几行外的所有行,那么上面的方法就不适合了
附:
C:\>dir /a-d /-c
驱动器 C 中的卷没有标签。
卷的序列号是 98C6-B5CC

C:\ 的目录

2006-09-22  11:32                 0 AUTOEXEC.BAT
2006-09-22  11:25               211 boot.ini
2004-08-17  20:00            322730 bootfont.bin
2006-09-22  11:32                 0 CONFIG.SYS
2006-08-12  19:30                 0 dfinstall.log
2007-09-17  08:17         266919936 hiberfil.sys
2006-09-22  11:32                 0 IO.SYS
2006-09-22  11:32                 0 MSDOS.SYS
2004-08-17  20:00             47564 NTDETECT.COM
2004-02-17  14:49            285344 ntldr
2007-09-17  08:28               206 ok.txt
2007-09-17  08:17         402653184 pagefile.sys
2007-09-17  08:18           8871936 Persi0.sys
2006-09-24  11:19             27214 _NavCClt.Log
              14 个文件      679128325 字节
               0 个目录    11131838464 可用字节

这时如果要处理除开头5行和结尾两行外的所有行那么楼上的方法就不行,不知那为达人 能提供更好的方法.

[ Last edited by renrenrenshk on 2007-9-17 at 09:15 AM ]
作者: wudixin96     时间: 2007-9-17 10:30
for /f "delims=" %%i in ('dir /a-d /-c^|findstr /r "[0-9]*-[0-9][0-9]-[0-9][0-9]"') do echo %%i

只针对6楼的问题


其实用sed可以很好的解决楼主的问题

[ Last edited by wudixin96 on 2007-9-17 at 10:31 AM ]
作者: terse     时间: 2007-9-17 10:42
处理指定行:
for /f "delims=" %%i in ('findstr /n .* test.txt') do (
        set /a mn=%%i 2>nul
        set "m=%%i"
        setlocal enabledelayedexpansion
        set m=!m:*:=!
        if !mn! GEQ 3 if !mn! LEQ 7 echo.!m!>>test2.txt
endlocal

[ Last edited by terse on 2007-9-18 at 12:30 AM ]
作者: 6692836     时间: 2007-9-17 15:58
4楼的程序没有问题.学习了
能解释一下for语句中的 delims=:的作用和findstr /n .* ok.txt的语法
我不懂 .谢谢了

[ Last edited by 6692836 on 2007-9-17 at 04:26 PM ]
作者: 6692836     时间: 2007-9-17 16:30
对不起,点错了.
作者: lxmxn     时间: 2007-9-17 16:39


  Quote:
Originally posted by 6692836 at 2007-9-17 15:58:
4楼的程序没有问题.学习了
能解释一下for语句中的 delims=:的作用和findstr /n .* ok.txt的语法
我不懂 .谢谢了

[ Last edited by 6692836 on 2007-9-17 at 04:26 PM ]

看看 findstr 命令的帮助,看看 /n 参数有什么用,你就会明白为什么这里的 for 会使用 "delims=:" 了.
作者: wudixin96     时间: 2007-9-17 16:42
我没有评2分的权限,帮不了你了,6692836
作者: renrenrenshk     时间: 2007-9-17 17:50
7楼  写的不错 很精辟!!!!!!!!!
-----------------------------------

下面针对九楼和四楼的 发表一下个人的观点。。。不是恶意攻击。。切莫误会。。

我们不是说四楼的代码有没有问题,而是四楼的代码不够精辟,代码中有些多余的东西 让人看了 反而不易理解 就像写程序要讲究算法优化和可读性,四楼的代码就犯了这两个错误。。。

[ Last edited by renrenrenshk on 2007-9-17 at 06:40 PM ]
作者: renrenrenshk     时间: 2007-9-17 18:16
虽然搂住的问题通过各种途径可以解决,但如果for语句中的skip可以完成这项功能,那么实现起来应该会更简单一些。。。 不知skip是否具有这个功能。。。等待达人指导。。。

[ Last edited by renrenrenshk on 2007-9-17 at 06:17 PM ]
作者: lxmxn     时间: 2007-9-17 18:46


  Quote:
Originally posted by renrenrenshk at 2007-9-17 09:12:
楼上的方法还不是非常灵活,比如dir命令的输出结果的行数是经常变的(随着文件夹的不同而不同),只有头尾几行是不变的,如果要处理除了那些不变 的几 ...

这位兄弟,4楼之前的帖子,你哪一点提到过关于dir命令了?
作者: renrenrenshk     时间: 2007-9-17 19:27
4楼之前的帖子,虽然没有提到过提到过关于dir命令了,但是dir命令的输出结果也是一楼的问题的一一种情况,因为同样要把头尾的几行扔掉,我们竟然考虑问题就应该尽可能的全面。。。你说你说是吧。
作者: lxmxn     时间: 2007-9-17 19:45
是啊,你说得太有道理了!
作者: renrenrenshk     时间: 2007-9-17 20:10
斑竹你别生气嘛 小弟初来贵宝地,发现人气特旺,所以只想把个人的想法说出去,如果说得不对,你就当我没说过 不是有意要冒犯您的。。。 还请多多海涵啊

[ Last edited by renrenrenshk on 2007-9-17 at 08:12 PM ]
作者: lxmxn     时间: 2007-9-17 20:12
是我没有考虑全面,请兄弟见谅.
作者: terse     时间: 2007-9-18 01:32
RE:6692836    -2分给我  
前帖发的虽然有欠缺
但在处理含有:开头的文件时 可以不被过滤掉:
作者: plp626     时间: 2008-4-2 21:39


  Quote:
Originally posted by wudixin96 at 2007-9-17 10:30 AM:
for /f "delims=" %%i in ('dir /a-d /-c^|findstr /r "[0-9]*-[0-9][0-9]-[0-9][0-9]"') do echo %%i

只针对6楼的问题


其实用sed可以很好的解决楼主的问题

...

其实还是烦了,既然都用到findstr还要for干甚
dir/a-d/-c|findstr /b 2008