标题: [文本处理] 【已解决】BAT:提取特定文本的前一个文本内的数据 [打印本页]
作者: 思想之翼 时间: 2014-6-15 04:25 标题: 【已解决】BAT:提取特定文本的前一个文本内的数据
lishi文件夹内有若干不同名称的txt文本,所有文本 按名称、递增属性排列。格式见附件。
本附件中 wj1文本的前一个(上一个)文本是 126次-1克.txt
由于lishi文件夹内文本时多时少,故wj1位置不固定,wj1前一个(上一个)文本的名称也不固定。
现在欲提取lishi文件夹内文本名为wj1的前一个(上一个)文本内的数据,至c盘名为“数据”的文件夹内,且命名为1.txt
这样的批处理代码如何写?
作者: Batcher 时间: 2014-6-15 10:06
你是按照什么属性排序的?我这里看到wj1文本的前一个(上一个)文本不是 126次-1克.txt
作者: 思想之翼 时间: 2014-6-15 11:00
本帖最后由 思想之翼 于 2014-6-15 16:13 编辑
回复 2# Batcher
感谢您的关注!
所有文本是按照 名称 递增 排列的
(操作系统 win7 64位)
作者: xxpinqz 时间: 2014-6-15 18:50
这题用bat貌似超难度了。就算不考虑只存在这两种命名格式的文件还得考虑相同前缀(-号前数值),不同的后缀。
作者: CrLf 时间: 2014-6-19 01:42
本帖最后由 CrLf 于 2014-6-19 03:50 编辑
用 gnu sort 与 sed:- @dir /a-d /b | sed "/[0-9]/!d;s/[^0-9]*\|[0-9]*/&|/g" | sort -n -t "|" -k1 -k2 -k3 -k4 -k5 -k6 -k7| sed "s/|//g"
复制代码
欢迎光临 批处理之家 (http://bathome.net./) |
Powered by Discuz! 7.2 |