二维码
微世推网

扫一扫关注

当前位置: 首页 » 快闻头条 » 科技资讯 » 正文

21_删除工作簿中多个工作表_22_提取多个工作表合

放大字体  缩小字体 发布日期:2023-03-09 12:41:40    作者:高齐懿    浏览次数:162
导读

实例21-删除工作簿中多个工作表Dim wbname As StringPrivate Sub CommandButton获取_Click()'获取工作簿中包含得工作表With ThisWorkbook.Worksheets("名称列表") '清除原列表数据.Columns(1).Clear

实例21-删除工作簿中多个工作表

Dim wbname As String

Private Sub CommandButton获取_Click()

'获取工作簿中包含得工作表

With ThisWorkbook.Worksheets("名称列表") '清除原列表数据

.Columns(1).ClearFormats

.Columns(1).ClearContents

.Columns(2).ClearFormats

.Columns(2).ClearContents

End With

With ThisWorkbook.Worksheets("操作界面")

If .Cells(2, "C").Value <> "" Then

wbname = .Cells(2, "C").Value

Else

MsgBox "请输入工作簿名称(包含扩展名)"

Exit Sub

End If

End With

Dim i As Integer

For i = 1 To Workbooks(wbname).Worksheets.Count

ThisWorkbook.Worksheets("名称列表").Cells(i, 1).Value = Workbooks(wbname).Worksheets(i).Name

Next i

ThisWorkbook.Worksheets("名称列表").Activate

End Sub

Private Sub CommandButton删除_Click()

Application.Displayalerts = False

With ThisWorkbook.Worksheets("操作界面")

If .Cells(2, "C").Value <> "" Then

wbname = .Cells(2, "C").Value

Else

MsgBox "请输入工作簿名称(包含扩展名)"

Exit Sub

End If

End With

With ThisWorkbook.Worksheets("名称列表")

Dim i As Long

Dim imax As Long

imax = .Cells(1000000, 1).End(xlUp).Row

For i = 1 To imax

If .Cells(i, 1).Value <> "" And .Cells(i, 2).Value <> "" Then

Workbooks(wbname).Worksheets(CStr(.Cells(i, 1).Value)).Delete

End If

Next i

Workbooks(wbname).Save

MsgBox "处理完成"

End With

Application.Displayalerts = True

End Sub

实例22-提取多个工作表合并为一个工作表

Dim wbname As String

Private Sub CommandButton获取_Click()

'获取工作簿中包含得工作表

With ThisWorkbook.Worksheets("名称列表") '清除原列表数据

.Columns(1).ClearFormats

.Columns(1).ClearContents

End With

With ThisWorkbook.Worksheets("操作界面")

If .Cells(2, "C").Value <> "" Then

wbname = .Cells(2, "C").Value

Else

MsgBox "请输入工作簿名称(包含扩展名)"

Exit Sub

End If

End With

Dim i As Integer

For i = 1 To Workbooks(wbname).Worksheets.Count

ThisWorkbook.Worksheets("名称列表").Cells(i, 1).Value = Workbooks(wbname).Worksheets(i).Name

Next i

ThisWorkbook.Worksheets("名称列表").Activate

End Sub

Private Sub CommandButton提取_Click()

With ThisWorkbook.Worksheets("提取结果") '清除原列表数据

.UsedRange.ClearFormats

.UsedRange.ClearContents

End With

With ThisWorkbook.Worksheets("操作界面")

If .Cells(2, "C").Value <> "" Then

wbname = .Cells(2, "C").Value

Else

MsgBox "请输入工作簿名称(包含扩展名)"

Exit Sub

End If

Dim extractrange As String

If .Cells(6, "C").Value <> "" Then

extractrange = .Cells(6, "C").Value

Else

MsgBox "请输入提取区域地址"

Exit Sub

End If

End With

Dim addrow As Long

With ThisWorkbook.Worksheets("名称列表")

Dim i As Long

Dim imax As Long

imax = .Cells(1000000, 1).End(xlUp).Row

For i = 1 To imax

If .Cells(i, 1).Value <> "" Then

With ThisWorkbook.Worksheets("提取结果")

addrow = .UsedRange.Cells(.UsedRange.Cells.Count).Row + 2

End With

Workbooks(wbname).Worksheets(CStr(.Cells(i, 1).Value)).Range(extractrange).Copy ThisWorkbook.Worksheets("提取结果").Cells(addrow, 1)

End If

Next i

MsgBox "处理完成"

End With

ThisWorkbook.Worksheets("提取结果").Activate

End Sub

 
(文/高齐懿)
打赏
免责声明
• 
本文为高齐懿原创作品•作者: 高齐懿。欢迎转载,转载请注明原文出处:http://www.udxd.com/news/show-372825.html 。本文仅代表作者个人观点,本站未对其内容进行核实,请读者仅做参考,如若文中涉及有违公德、触犯法律的内容,一经发现,立即删除,作者需自行承担相应责任。涉及到版权或其他问题,请及时联系我们邮件:weilaitui@qq.com。
 

Copyright©2015-2023 粤公网安备 44030702000869号

粤ICP备16078936号

微信

关注
微信

微信二维码

WAP二维码

客服

联系
客服

联系客服:

24在线QQ: 770665880

客服电话: 020-82301567

E_mail邮箱: weilaitui@qq.com

微信公众号: weishitui

韩瑞 小英 张泽

工作时间:

周一至周五: 08:00 - 24:00

反馈

用户
反馈