中国DOS联盟论坛

中国DOS联盟

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

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

游客:  注册 | 登录 | 命令行 | 会员 | 搜索 | 上传 | 帮助 »
作者:
标题: [已结]多条件提取数据 上一主题 | 下一主题
hgx126
初级用户





积分 100
发帖 80
注册 2008-9-12
状态 离线
『楼 主』:  [已结]多条件提取数据

一文件目录下有多个文本,其中一个文本a.txt内容如下:

  Quote:
5411|12810001|4|4001|0|1992-12-10|1993-6-30|0|0|安德顺
5411|12510101|0|4002|70000|2008-1-23|2009-1-21|1981.07|2002.84|安德顺
5411|12510201|0|4052|80000|2008-6-6|2011-6-5|0|0|安德阳
5411|12310001|0|4001|0|2007-9-21|2008-9-19|0|0|安光明
5411|12340601|1|4303|28000|2008-10-13|2009-10-12|0|0|安光明
5411|12710001|3|4001|0|1999-7-2|2000-1-2|0|16144.18|安和平
5411|12710001|3|4001|10|1999-8-2|2000-8-2|0|17003.68|安和平

现要将满足以下其中任意一个条件的该行数据提取到b.txt,但b.txt中不能有重复的数据。(以|为分隔符)
1、第五列数据不为0;
2、第八列数据不为0;
3、第九列数据不为0;

求一批处理,批量将该目录下的所有文本里满足条件的数据提取出来。求
大家帮忙。

[ Last edited by HAT on 2009-2-3 at 05:30 ]

2009-2-2 14:21
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
hgx126
初级用户





积分 100
发帖 80
注册 2008-9-12
状态 离线
『第 2 楼』:  

或可以这样理解:即将a.txt中第五列数据、第八列数据、第九列数据同时为0的该行数据删除。

2009-2-2 14:31
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
wxcute
中级用户





积分 458
发帖 211
注册 2006-7-26
状态 离线
『第 3 楼』:  

测试如果正确,请将 echo %%I 变成 echo %%I>>b.txt
@echo off
for /f "delims=" %%I in (a.txt) do (
 set flag=
 for /f "tokens=1-9* delims=|" %%a in ("%%I") do (
  if %%e neq 0 set flag=1
  if %%h neq 0 set flag=1
  if %%i neq 0 set flag=1
 )
 if defined flag echo %%I
)
pause
goto :eof




┌───────┐
├→学习→实践→┤
└───────┘
2009-2-2 15:23
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
yishanju
银牌会员

[b]看你妹啊[/b]


积分 1488
发帖 1357
注册 2006-5-20
状态 离线
『第 4 楼』:  

MS findstr 命令就可以了




有问题请发论坛或者自行搜索,再短消息问我的统统是SB
2009-2-2 15:27
查看资料  发短消息 网志   编辑帖子  回复  引用回复
yishanju
银牌会员

[b]看你妹啊[/b]


积分 1488
发帖 1357
注册 2006-5-20
状态 离线
『第 5 楼』:  

findstr /r /v /c:".*[|].*[|].*[|].*[|]0[|].*[|].*[|]0[|]0[|].*" *.txt>>test.txt
pause

   此帖被 +9 点积分      点击查看详情   
评分人:【 moniuming 分数: +5  时间:2009-2-2 20:18
评分人:【 wxcute 分数: +4  时间:2009-2-5 20:27





有问题请发论坛或者自行搜索,再短消息问我的统统是SB
2009-2-2 19:07
查看资料  发短消息 网志   编辑帖子  回复  引用回复
yishanju
银牌会员

[b]看你妹啊[/b]


积分 1488
发帖 1357
注册 2006-5-20
状态 离线
『第 6 楼』:  

我觉得我还是写得太繁杂了,想知道更简单的代码




有问题请发论坛或者自行搜索,再短消息问我的统统是SB
2009-2-2 21:10
查看资料  发短消息 网志   编辑帖子  回复  引用回复
hgx126
初级用户





积分 100
发帖 80
注册 2008-9-12
状态 离线
『第 7 楼』:  

感谢各位,我用wxcute的办法解决了。谢谢

2009-2-2 22:04
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
yishanju
银牌会员

[b]看你妹啊[/b]


积分 1488
发帖 1357
注册 2006-5-20
状态 离线
『第 8 楼』:  

type *.txt|findstr /r /c:".*[|].*[|].*[|].*[|][^0].*[|].*[|].*[|].*[|].*[|].*" /c:".*[|].*[|].*[|].*[|].*[|].*[|].*[|][^0].*[|].*[|].*" /c:".*[|].*[|].*[|].*[|].*[|].*[|].*[|].*[|][^0].*[|].*" >>bb.txt

嘎嘎,又新写了一个更长的




有问题请发论坛或者自行搜索,再短消息问我的统统是SB
2009-2-5 17:00
查看资料  发短消息 网志   编辑帖子  回复  引用回复
yishanju
银牌会员

[b]看你妹啊[/b]


积分 1488
发帖 1357
注册 2006-5-20
状态 离线
『第 9 楼』:  

原来findstr 还可以这样用
生成的结果很干净,也符合一楼里的帖子要求,最终完美版^_^:
type *.txt|findstr /rvc:".*[|].*[|].*[|].*[|]0[|].*[|].*[|]0[|]0[|].*" /rvc:".*[.]txt" >>b.txt

[ Last edited by yishanju on 2009-2-5 at 21:08 ]




有问题请发论坛或者自行搜索,再短消息问我的统统是SB
2009-2-5 21:06
查看资料  发短消息 网志   编辑帖子  回复  引用回复

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


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



论坛跳转: