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

[问题求助] [已解决]VBS脚本怎样获取Excel文件里面有哪些Worksheet?

本帖最后由 gawk 于 2012-5-18 06:47 编辑

我有一个Excel文件,里面有30多个Worksheet,怎样用VBS脚本导出它们的名称呢?
1

评分人数

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

导出成jpg

TOP

本帖最后由 Demon 于 2012-5-17 14:40 编辑


'Author: Demon
'Website: http://demon.tw
'Date: 2012/5/17
Option Explicit
'Must be full path
Const xls = "C:\Users\Demon\Desktop\demo.xls"
Dim Excel, Workbook, Worksheet
Set Excel = WScript.CreateObject("Excel.Application")
Set Workbook = Excel.Workbooks.Open(xls)
For Each Worksheet In Workbook.Worksheets
    WScript.Echo Worksheet.Name
Next
Workbook.Close
Excel.Quit
1

评分人数

    • gawk: 乐于助人技术 + 1

TOP

如果没有安装excel(比如我)
  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;"";"
  4. Set AdoCnn = CreateObject("ADODB.Connection")
  5. AdoCnn.Open strConnect
  6. Set rs = AdoCnn.OpenSchema(20)
  7. Do Until rs.EOF
  8.     WScript.Echo rs.Fields("table_name")
  9.     rs.MoveNext
  10. Loop
  11. AdoCnn.Close
复制代码
适当整理一下即可(ado有个小问题是会把名字中的点.替换为#,如果结果中出现#则无法得知确切名称)。

TOP

回复 3# Demon


    测试成功,感谢分享。

TOP

回复 4# powerbat


测试发现的几个小问题:
1、得到的列表没有按照原来的顺序,被排序了。
2、行尾多了$符号。
3、有空格的sheet的行首和行尾还被加了单引号。

不会调整

TOP

返回列表