中国DOS联盟论坛

中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net  论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

游客:  注册 | 登录 | 命令行 | 会员 | 搜索 | 上传 | 帮助 »
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » 如何在文本中提取两个特征码之间的字符?
作者:
标题: 如何在文本中提取两个特征码之间的字符? 上一主题 | 下一主题
lixinwu
初级用户





积分 31
发帖 14
注册 2006-7-12
状态 离线
『楼 主』:  如何在文本中提取两个特征码之间的字符?

从文本中提取指定的ip地址并导出,提取<TD class=name>和</TD>之间的ip,文本0.txt如下:
           <TD class=speed>Russian Federation </TD></TR>
        <TR>
          <TD class=name>127.0.0.1:8000 </TD>
          <TD class=countgood>1835 </TD>
          <TD class=speed>United States </TD></TR>
        <TR>
          <TD class=name>157.0.0.2:3128 </TD>
          <TD class=cont1></TD>
          <TD class=speed>Denmark </TD></TR>
        <TR>
          <TD class=name>212.47.86.217:8080 </TD>
我这个批处理总是不成功,请各位看看错在哪里了?
for /f "tokens=1,2 delims=e^>" %%a in ('type 0.txt ^| findstr /c:"^</T" ') do (
        set set=%%a
        set "set=!set!"
echo  !set! >>1.txt
)
[ Last edited by namejm on 2007-1-26 at 05:46 PM ]

2007-1-27 00:27
查看资料  发短消息 网志   编辑帖子  回复  引用回复
namejm
荣誉版主

batch fan


积分 5226
发帖 1737
注册 2006-3-10
来自 成都
状态 离线
『第 2 楼』:  

  选好分隔符号很重要,试试下面的代码:
@echo off
for /f "tokens=2 delims=>:" %%i in ('findstr \. 0.txt') do echo %%i
pause


   此帖被 +5 点积分      点击查看详情   
评分人:【 ccwan 分数: +5  时间:2007-2-4 00:42




尺有所短,寸有所长,学好CMD没商量。
考虑问题复杂化,解决问题简洁化。
2007-1-27 01:33
查看资料  发短消息 网志   编辑帖子  回复  引用回复
lixinwu
初级用户





积分 31
发帖 14
注册 2006-7-12
状态 离线
『第 3 楼』:  

多谢了,好用,学习中。。。。

2007-1-27 03:49
查看资料  发短消息 网志   编辑帖子  回复  引用回复
amao
中级用户





积分 316
发帖 152
注册 2006-6-18
状态 离线
『第 4 楼』:  

@sed "/:/!d;s/.*>\(.*\):.*/\1/" 0.txt

2007-2-3 21:28
查看资料  发短消息 网志   编辑帖子  回复  引用回复
anqing
高级用户




积分 859
发帖 413
注册 2006-8-14
状态 离线
『第 5 楼』:  

@echo off
for /f "tokens=2 delims=>:" %%i in ('findstr \. 0.txt') do echo %%i
pause
这种用法头一次看到
sed命令真强,不过可惜要下载?不是原来的xp命令,在xp中它和for即使有速度上的差别,也可忽略,必竟p是小程序

2007-2-3 23:46
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
flyingphf
中级用户





积分 392
发帖 142
注册 2007-6-10
状态 离线
『第 6 楼』:  

这个sed命令我看不大懂啊,能具体说一下吗,如果中间是中文可以提取的吗

2008-3-30 15:17
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
wzq5510
新手上路





积分 19
发帖 9
注册 2008-3-24
状态 离线
『第 7 楼』:  

我饿得我

2008-3-30 19:01
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
sylovanas
初级用户





积分 107
发帖 42
注册 2007-9-3
状态 离线
『第 8 楼』:  

/:/!d
不包含:字串的行删除

s/.*>\(.*\):.*/\1/
将一行中有>任意字串到:任意字串到结尾的行改成()之内的字串

如果要搜寻中文建议用变量,但可能会牵扯到字码问题

2008-3-30 19:39
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复

请注意:您目前尚未注册或登录,请您注册登录以使用论坛的各项功能,例如发表和回复帖子等。


可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题



论坛跳转: