标题: [文本处理] 【已解决】批处理如何提取多个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 编辑
- @echo off
- setlocal enabledelayedexpansion
- rem for %%a in (*.txt) do ……
- for /f "delims=" %%a in ('dir /a-d/b *.txt') do (
- set n=1000000000
- for /f "tokens=1-4*" %%b in ('type "%%a"') do (
- set /a n+=1
- for %%i in (!n!) do set "#%%i_%%b=!#%%i_%%b! %%e"
- )
- )
- for /f "tokens=1*delims==" %%a in ('set #') do set "str=%%a"&echo;!str:*_=!!%%a!
- pause
复制代码
作者: pcl_test 时间: 2016-7-3 17:07
本帖最后由 pcl_test 于 2016-7-3 20:38 编辑
- //&cls&dir /a-d/b *.txt|cscript -nologo -e:jscript "%~f0"&pause&exit
- var fso=new ActiveXObject('Scripting.Filesystemobject');
- var n=4, t={}; //指定第4列
- while(!WSH.StdIn.AtEndOfStream){
- var f = fso.OpenTextFile(WSH.StdIn.ReadLine(), 1);
- while(!f.AtEndOfStream){
- var line = f.ReadLine().split(/\s+/);
- if(line != ''){
- if(!line[n-1])line[n-1]='*';
- t[line[0]]=t[line[0]]?t[line[0]]+' '+line[n-1]:line[n-1];
- }
- }
- }
- 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 |