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

[文本处理] 批处理怎样取特定位置字符串,然后追加到指定文件?

[复制链接]
发表于 2019-2-20 16:17:12 | 显示全部楼层 |阅读模式
如题:

请各位大侠帮助我解决这个问题。

当前文件夹下有一系列格式相同但内容不同的文本文件*.txt,一个文本文件只有1行内容,被;分号分割为221列。
需要抓取其中的1、2、3、4、5、161、181、191、201、202、211、212列中的内容,追加到当前文件夹下指定文件XXXX.CSV中,还是用;分号隔开。每个文件占一行。第一行为标题栏,暂定为1、2、3、4、5、161、181、191、201、202、211、212(可以自己以后定义),也是用;分号隔开。

已经知道如何将每个文本文件的内容,追加到当前文件夹下指定文件XXXX.CSV中了。如下:
  1. (for /f "delims=" %%i in ('dir /b *.txt') do (type "%%i"&echo,) 9>>%%a)>>XXXX.CSV 2>nul
复制代码
谢谢
发表于 2019-2-20 18:14:34 | 显示全部楼层
@echo off
setlocal enabledelayedexpansion
for /f "delims=" %%i in ('type 1.txt') do (
set var=%%i
set var=!var:;= !
)
for %%j in (1 2 4) do (
set a=0
for %%k in (!var!) do (
set /a a+=1
if !a!==%%j (set k=!k!%%k;)
)
)
echo !k! >test.csv
pause >nul
发表于 2019-2-20 18:18:18 | 显示全部楼层
回复 2# an1294803265


    这是取了一个文本来测试,你自己改成取多个文本吧,原理就是这么个原理
 楼主| 发表于 2019-2-20 21:36:31 | 显示全部楼层
谢谢,让我想想,试试
发表于 2019-2-21 15:46:49 | 显示全部楼层
不用想 数组分割 PS法

  1. $title = 'T1;T2;T3;T4;T5;T6;T7;T8;T9;T10;T11;T12';
  2. $Vol = 1,2,3,4,5,161,181,191,201,202,211,212; #可修改要取值的列。
  3. sc '.\xxx.csv' -value $title -force;
  4. $index = @( $Vol | %{ $_ -1 });
  5. ls '*.txt' | %{ $F=(gc $_).Split(';');ac '.\xxx.csv' -value $($F[$index] -join';')}
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-19 00:02 , Processed in 0.011115 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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