找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 21941|回复: 3

[文本处理] 批处理如何实现如此排列档案?

[复制链接]
发表于 2012-4-16 17:43:19 | 显示全部楼层 |阅读模式
我有一个档案,如下格式:
num  Spell         type  Exp
521        below        adv        aa1
521        below        prep        bb1
521        under        prep        cc1
521        under        prep        cc2
521        under        prep        cc3
521        under        prep        cc4
521        under        adv        dd1
521        under        adv        dd2
521        under        adj        ee1
521        underneath        adv        ff1

处理成如下格式,以下共有4条记录:
<pre>
below        adv        aa1        below        prep        bb1        under        prep        cc1        under        adv        dd1        underneath        adv        ff1
                                                                under        prep        cc2        under        adv        dd2
                                                                under        prep        cc3
                                                                under        prep        cc4
</pre>
即num 相同的,根据 spell ,type 排列,如果spell 和type 相同,则新增记录,否则接在第一条记录后面。
发表于 2012-4-17 09:11:08 | 显示全部楼层
num 相同的,根据 spell ,type 排列,如果spell 和type 相同,则新增记录,否则接在第一条记录后面

1.第一列num全部相同,用不着筛选;
2.under        adv        dd2为何接在第二条后面?
 楼主| 发表于 2012-4-17 11:36:09 | 显示全部楼层
under        adv        dd2为何接在第二条后面?
其实上面是4条记录(漏掉了under        adj        ee1的情况 ),under        prep        cc2        under        adv        dd2 在一条记录里面
其实是想做到凡是 spell , type 相同的,就要将exp 资料新开记录,然后竖行对应。
发表于 2012-4-17 18:43:45 | 显示全部楼层
看看是不是你需要的:
  1. @echo off&setlocal enabledelayedexpansion
  2. (for /f "skip=1 tokens=2-4 delims= " %%a in (a.txt) do (
  3.   if not defined %%a%%b (
  4.     set "str=!str! %%a %%b %%c"
  5.     set %%a%%b=1
  6.   ) else echo %%a %%b %%c
  7. ))>$
  8. (echo !str:~1!&type $)>b.txt
  9. del $
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-19 03:32 , Processed in 0.016648 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表