Board logo

标题: [文本处理] 【已解决】批处理如何提取多个txt文本的指定列的内容并按指定格式合并输出? [打印本页]

作者: jrx401    时间: 2016-7-1 23:49     标题: 【已解决】批处理如何提取多个txt文本的指定列的内容并按指定格式合并输出?

本帖最后由 jrx401 于 2016-7-4 22:14 编辑

[文件举例]
文件名称1:123.txt
文件内容:
a1 231 zdfe4 as vrr
b1 2314 f44fw bs 12ed
b3 23s f4sad 1sdd 1sdd

文件名称2:acb.txt
文件内容:
a1 561 zdfe4 356 nhg
b1 3244 33fw 2dd 1ffd
b3 23 333ad cxd ffd

文件名称3:3j3.txt
文件内容:
a1 561 zdfe4 cc nhg
b1 3244 33fw bb 1ffd
b3 23 333ad 11 ffd

......

有无数类似以上文件(只有第一列是一样的),如果指定第四列,合并后如下;
文件名称:total.txt
a1 as 356 cc ...
b1 bs 2dd bb ...
b3 1sdd cxd 11 ...
作者: hlzj88    时间: 2016-7-2 06:48

n个文本的的所有同一行的指定列合并为一行,生成新文本。
等看高手风采
作者: jrx401    时间: 2016-7-3 12:23

回复 2# hlzj88


    不知道哪位高手指点一下呢?
作者: pcl_test    时间: 2016-7-3 15:59

本帖最后由 pcl_test 于 2016-7-4 10:56 编辑
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. rem for %%a in (*.txt) do ……
  4. for /f "delims=" %%a in ('dir /a-d/b *.txt') do (
  5.     set n=1000000000
  6.     for /f "tokens=1-4*" %%b in ('type "%%a"') do (
  7.         set /a n+=1
  8.         for %%i in (!n!) do set "#%%i_%%b=!#%%i_%%b! %%e"
  9.     )
  10. )
  11. for /f "tokens=1*delims==" %%a in ('set #') do set "str=%%a"&echo;!str:*_=!!%%a!
  12. pause
复制代码

作者: pcl_test    时间: 2016-7-3 17:07

本帖最后由 pcl_test 于 2016-7-3 20:38 编辑
  1. //&cls&dir /a-d/b *.txt|cscript -nologo -e:jscript "%~f0"&pause&exit
  2. var fso=new ActiveXObject('Scripting.Filesystemobject');
  3. var n=4, t={};  //指定第4列
  4. while(!WSH.StdIn.AtEndOfStream){
  5.     var f = fso.OpenTextFile(WSH.StdIn.ReadLine(), 1);
  6.     while(!f.AtEndOfStream){
  7.         var line = f.ReadLine().split(/\s+/);
  8.         if(line != ''){
  9.             if(!line[n-1])line[n-1]='*';
  10.             t[line[0]]=t[line[0]]?t[line[0]]+' '+line[n-1]:line[n-1];
  11.         }
  12.     }
  13. }
  14. for(var i in t)WSH.echo(i+' '+t[i]);
复制代码

作者: jrx401    时间: 2016-7-4 22:02

回复 4# pcl_test


   
感谢板主出手。
我的知识浅薄,研究了一下但是如下无法吃透。
1. 如下代码的# 符号是代表什么呢?
    for %%i in (!n!) do set "#%%i_%%b=!#%%i_%%b! %%e"
2.还有如下部分的 内容,特别是str=%%a"&echo;!str:*_=!!%% 部分。
for /f "tokens=1*delims==" %%a in ('set #') do set "str=%%a"&echo;!str:*_=!!%%a!

还请相助。
或介绍学习资料也可。
非常感谢。




欢迎光临 批处理之家 (http://www.bathome.net/) Powered by Discuz! 7.2