Board logo

标题: [文本处理] 【已解决】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:
  1. @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