[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[文件操作] 【已解决】批处理怎样把多个txt导入Excel?

本帖最后由 wenlishasha 于 2014-6-11 19:50 编辑

求助论坛高手,有没有办法批量把多个txt导入到excel中,要求:
1个txt做一行(每个txt可能有多行,每行做excel的一个单元格)
1

评分人数

    • Batcher: 感谢给帖子标题标注[已解决]字样PB + 2

  1. for /f "delims=" %%a in (1.txt) do >>1.csv echo %%a
复制代码

TOP

回复 2# 522235677


    谢谢!
但一次只能导入一个txt
而且一个txt导进去了成为了多行

TOP

回复 3# wenlishasha
你是要一个txt缩成一行然后放在一个单元格里?
  1. @echo off
  2. for /f "delims=" %%a in ('dir /b *.txt') do (
  3. (for /f "delims=" %%b in (%%a) do <nul set /p=%%b)>>1.csv
  4. echo.>>1.csv
  5. )
  6. pause
复制代码

TOP

回复 4# 522235677


    文本内容有逗号就会出问题吧

TOP

回复 5# DAIC


    恩,你有啥办法没有

TOP

  1. @set @n=0; /* & echo off
  2. dir /b *.txt | cscript -nologo -e:jscript "%~0" "%~dp0"
  3. pause & exit/b & rem */
  4. var fso = new ActiveXObject("Scripting.FileSystemObject");
  5. var oExcel = new ActiveXObject("Excel.Application");
  6. oExcel.Visible = false
  7. var oBook = oExcel.WorkBooks.Add(); i=1;
  8. while (!WScript.StdIn.AtEndOfStream) {
  9.     var f = WScript.StdIn.ReadLine();
  10.     var txt = fso.OpenTextFile(f).ReadAll();
  11.     var ar = txt.replace(/\r?\n/g,"\n").split("\n");
  12.     for (var j=0; j<ar.length; j++) {
  13.         oExcel.Cells(i,j+1) = ar[j];
  14.     }
  15.     i+=1;
  16. }
  17. oBook.SaveAs(WScript.Arguments(0) + "Result.xls");
  18. oExcel.WorkBooks.Close();
  19. oExcel.Quit();
  20. fso = null; oExcel = null; oBook = null
复制代码
1

评分人数

TOP

  1. @echo off
  2. for /f "delims=" %%a in ('dir /b *.txt') do (
  3.         (for /f "delims=" %%b in (%%~sa) do <nul set /p=%%b,)>>1.csv
  4.         echo.>>1.csv
  5. )
  6. pause
复制代码
看了三遍才把你的意思看明白了
1

评分人数

TOP

返回列表