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

[文本处理] 【已解决】BAT怎样批量导入文本到csv表格中?

[复制链接]
发表于 2020-4-26 23:34:03 | 显示全部楼层 |阅读模式
本帖最后由 不知道是谁 于 2020-4-27 20:50 编辑

a.txt文件如下:
1:ab,cd
2:张三
3:300
4:3000

b.txt文件如下:
1:efgh
2:李四
3:400
4:4000

想达到的效果如下:
  1         2       3        4
ab,cd   张三   300   3000
efgh    李四   400   4000

在必须保留逗号的情况下,下面的批处理要怎么修改?
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. set file=table.csv
  4. >%file% echo 1,2,3,4
  5. for /f "delims=" %%i in ('dir /b *.txt') do (
  6.     set name=%%i
  7.     for /f "tokens=2 delims=:" %%j in (!name!) do (
  8.         set /p =%%j,<nul>>%file%
  9.         set /a num+=1
  10.         if !num! equ 4 (
  11.             echo,>>%file%
  12.             set num=0
  13.         )
  14.     )
  15. )
复制代码
发表于 2020-4-27 05:48:30 | 显示全部楼层
回复 1# 不知道是谁


    csv支持引号
发表于 2020-4-27 18:26:30 | 显示全部楼层
回复 1# 不知道是谁
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. set file=table.csv
  4. >%file% echo 1,2,3,4
  5. for /f "delims=" %%i in ('dir /b *.txt') do (
  6.     set name=%%i
  7.     for /f "tokens=2 delims=:" %%j in (!name!) do (
  8.         set /p =""%%j""<nul>>%file%
  9.         set /p =,<nul>>%file%
  10.         set /a num+=1
  11.         if !num! equ 4 (
  12.             echo,>>%file%
  13.             set num=0
  14.         )
  15.     )
  16. )
复制代码

评分

参与人数 1技术 +1 收起 理由
不知道是谁 + 1 乐于助人

查看全部评分

您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-19 21:11 , Processed in 0.018768 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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