标题: 请教eol=可否忽略多个?
[打印本页]
作者: FBOAR
时间: 2007-1-16 00:26
标题: 请教eol=可否忽略多个?
我想忽略以;和s开头的行
eol=;,s 行不通
此句该如何写?

作者: vkill
时间: 2007-1-16 00:30
貌似不可以
作者: oilio
时间: 2007-1-16 01:39
命令解释就是指定一个啊,没听说可以那样搞,如果有人那样能搞成功,还真的期待。。。。
作者: redtek
时间: 2007-1-16 01:53
假如要滤掉下面 A.TXT 文件中 “;” 和 “S” 开头的行内容:
;China
;Beijing
ShangHai
NanJing
;DaLian
HeBei
HeNan
中国
北京
上海
@echo off
for /f "eol=;" %%a in ('for /f "eol=S" %%b in ^(a.txt^) do @echo %%b') do echo %%a
分两次间接实现:(棕色)部分代码将滤掉 “S” 字母之后的字符串再次给它的调用者(黑色)部分代码。
而(黑色)部分代码 for 中的 eol 参数又会把 “;” 符号滤过,最后结果就等于间接实现了同时滤掉 “;” 和 “S” 这两个字符。
上面输出结果:
NanJing
HeBei
HeNan
中国
北京
上海
注: eol 参数区分字母的大小写
eol 参数可以滤掉一个中文汉字(它同样把一个汉字当做象英文字母一样的一个“字节”来看待)
Last edited by redtek on 2007-1-15 at 12:54 PM ]
作者: 9527
时间: 2007-1-16 01:59
有些时候不要把问题想的都这么复杂,可以用FOR进行二次过滤啊,虽然影响速度那也比一个个的弄好啊
演示文本
good
hello
ssldjf
ppp
ssss
nnnns
sdl,nf
kkkskdhnkfsdf
jhk
kdkkk
对应过滤代码如下:
@echo off&setlocal
for /f "eol=s tokens=*" %%a in (ii.txt) do (
for /f "eol=k tokens=*" %%x in ('echo/%%a') do echo %%x
)
虽然没有进行对特殊字符情况的考虑,不过你可以在次改造来实现啊
作者: 9527
时间: 2007-1-16 02:00
呵呵,redtek兄抢先了....当灌水了
Last edited by 9527 on 2007-1-16 at 02:02 AM ]
作者: vkill
时间: 2007-1-16 02:06
要是很多那?
作者: lxmxn
时间: 2007-1-16 05:07
Originally posted by vkill at 2007-1-15 13:06:
要是很多那?
可以变通一下,用findstr /v。我的a.txt文档:
China
Hubei
catalog
Visual FoxPro
China DOS Union
Windows Management Instrumentation Commandline
www.cn-dos.net
People
Vbscript and Javascript
中国DOS联盟
批处理脚本技术
Welcome to China DOS Union
You will learn much more from this forum.
忽略以"C"、"V"、"中"开始的所有行:
@echo off
(for /f "delims=" %%a in ('findstr /v "^C.* ^中.* ^V.*" a.txt') do (echo=%%a))&pause&exit/b 0
作者: Eblis
时间: 2007-1-16 13:50
lxmxn.高哇..这样可以忽略很多了...
作者: lxmxn
时间: 2007-1-16 14:21
嘿嘿,批处理就是没有做不到,只有想不到。
作者: FBOAR
时间: 2007-1-17 01:21
感谢楼上几位朋友的回答 谢谢
作者: luowei14
时间: 2007-1-18 07:39
看来FOR 命令要多学学了 。。。
作者: beeny
时间: 2007-1-18 12:31
Originally posted by lxmxn at 2007-1-15 04:07 PM:
可以变通一下,用findstr /v。我的a.txt文档:
忽略以"C"、"V"、"中"开始的所有行:
@echo off
(for /f "delims=" %%a in ('findstr /v "^C.* ^中.* ^V.*" a.txt') do (echo=%%a))&pause&exit/b 0
红色部分中^这个符号是什么意思,为什么要用这个符号?
作者: lxmxn
时间: 2007-1-18 13:51
^符号在findstr里面代表匹配一个字符串的开头,而$代表匹配一个字符串的结尾,具体说明请看findstr /?。
作者: oilio
时间: 2007-1-28 06:19
lxmxn兄,我用过你说的方法,忽略以字符打头的行,我知道了。忽略以某某字符结尾的行,我没有试出来,不知道问题出在什么地方,看一下帮助命令,也没有发现什么。我是这样用的。忽略以“e,n,术”结尾的行
for /f "delims=" %a in ('findstr /v "$e.* $n.* $术.*" a.txt') do @echo %a
不知道错在什么地方,高手指点一下啊,在这儿谢过了。
作者: lxmxn
时间: 2007-1-28 11:03
Re oilio:
你这样试试:
for /f "delims=" %a in ('findstr /v ".*e$ .*n$ .*术$" a.txt') do @echo %a
作者: oilio
时间: 2007-1-29 00:12
谢谢,我好像明白了问题所在之处,谢谢。
作者: zhclvip
时间: 2007-1-30 00:23
eol=c - 指一个行注释字符的结尾(就一个)