Foxtable(狐表)用户栏目专家坐堂 → [求助]在一个Excel工作薄里导出多表


  共有1912人关注过本帖树形打印复制链接

主题:[求助]在一个Excel工作薄里导出多表

帅哥,在线噢!
有点蓝
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110768 积分:563772 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2024/1/16 10:07:00 [显示全部帖子]

第一个表格导到Dim Sheet As XLS.Sheet = Book.Sheets(0)
第二个表格导到Dim Sheet As XLS.Sheet = Book.Sheets(1)
第三个表格导到Dim Sheet As XLS.Sheet = Book.Sheets(2)

 回到顶部
帅哥,在线噢!
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110768 积分:563772 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2024/1/16 11:09:00 [显示全部帖子]


 回到顶部
帅哥,在线噢!
有点蓝
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110768 积分:563772 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2024/1/16 11:52:00 [显示全部帖子]

可以简化一下

Dim tbs() As String = {"台账一", "台账二", "台账三"}
Dim Book As New XLS.Book
For j As Integer = 1 To tbs.length - 1
    Book.Sheets.Add()
Next
Dim tbl As Table
For i As Integer = 0 To tbs.length - 1
    tbl = Tables(tbs(i))
    Dim hdr2 As Integer = tbl.HeaderRows '获得表头的层数
    Dim cnt2 As Integer = 0
    Dim Sheet As XLS.Sheet = Book.Sheets(i)
    tbl.CreateSheetHeader(Sheet) '生成表头
    For c2 As Integer = 0 To tbl.Cols.Count - 1
        If tbl.Cols(c2).Visible Then
            For r2 As Integer = 0 To tbl.Rows.Count - 1
                sheet2(r2 + hdr2, cnt2).value = tbl(r2, c2)
            Next
            cnt2 = cnt2 + 1
        End If
    Next
Next

Dim dlg As New SaveFileDialog '定义一个新的SaveFileDialog
dlg.Filter = "Excel文件|*.xls" '设置筛选器
dlg.FileName = "汇总台账"
If dlg.ShowDialog = DialogResult.Ok Then
    Book.Save(dlg.FileName)
    Dim Proc As New Process
    Proc.File = dlg.FileName
    Proc.Start()
End If

 回到顶部