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

[问题求助] [已解决]VBS脚本怎样把Excel中的多个sheet转换成一个txt?

[复制链接]
发表于 2012-5-18 07:08:58 | 显示全部楼层 |阅读模式
本帖最后由 gawk 于 2012-5-19 02:38 编辑

我找到一个把每个sheet单独转换成一个txt的,但是我想把一个Excel文件里面的所有sheet全部转换到一个txt,怎么办?
http://www.bathome.net/thread-10806-1-1.html

评分

参与人数 1PB +2 收起 理由
zqz0012005 + 2 感谢给帖子标题标注[已解决]字样

查看全部评分

发表于 2012-5-18 09:47:32 | 显示全部楼层
  1. xls = "C:\Users\root\Desktop\1.02战法数据表.xls"

  2. strConnect = "Provider=Microsoft.Jet.OLEDB.4.0;" & _
  3.     "Data Source=" & xls & ";Extended Properties=""Excel 8.0;HDR=no;IMEX=1;"";"

  4. Set AdoCnn = CreateObject("ADODB.Connection")
  5. AdoCnn.Open strConnect
  6. Set rs = AdoCnn.OpenSchema(20)
  7. Do Until rs.EOF
  8.     tbl = rs.Fields("table_name")
  9.     s = s & tbl & vbCrLf & String(40,"-") & vbCrLf
  10.     s = s & AdoCnn.Execute("select * from [" & tbl & "]").GetString(2)
  11.     s = s & String(80,"=") & vbCrLf & vbCrLf
  12.     rs.MoveNext
  13. Loop
  14. AdoCnn.Close
  15. WScript.Echo s
复制代码
发表于 2012-5-18 15:42:31 | 显示全部楼层
单独转后合并不就行了
 楼主| 发表于 2012-5-18 22:06:42 | 显示全部楼层
回复 2# powerbat


报错信息如下:
c:\Test>cscript //nologo test.vbs >a.txt
c:\Test\test.vbs(12, 5) Microsoft JET Database Engine: Too many fields defined.

我的xls文件里面有几十个sheet,是不是因为东西太多了?
 楼主| 发表于 2012-5-18 22:08:46 | 显示全部楼层
回复 3# Demon


不想生成几十个临时文件,觉得不够优雅。
发表于 2012-5-19 01:04:57 | 显示全部楼层
  1. '将 XLS 文件拖到此 VBS 中,将生成同名 TXT 文本文件。
  2. Filename = WScript.Arguments(0)
  3. Set ExcelApp = CreateObject("Excel.Application")
  4. Set ExcelOut = ExcelApp.Workbooks.Open(Filename)
  5. If LCase(Right(Filename,4))=".xls" Then
  6.     RowC = ExcelOut.WorkSheets(1).UsedRange.Rows.Count
  7.     For i = 2 to ExcelOut.WorkSheets.Count
  8.         ExcelOut.WorkSheets(i).UsedRange.Copy
  9.         ExcelOut.WorkSheets(1).Range("A" & RowC + 1).PasteSpecial
  10.         RowC = RowC + ExcelOut.WorkSheets(i).UsedRange.Rows.Count
  11.     Next
  12.     ExcelOut.WorkSheets(1).SaveAs Left(Filename,instrrev(Filename,".")) & "TXT",3
  13. End If
  14. ExcelOut.Saved = True
  15. ExcelOut.Close
  16. Wscript.Quit
复制代码

评分

参与人数 1技术 +1 收起 理由
gawk + 1 乐于助人

查看全部评分

 楼主| 发表于 2012-5-19 02:38:30 | 显示全部楼层
回复 6# cutebe


    测试成功,多谢。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-17 15:29 , Processed in 0.018094 second(s), 9 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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