VBS实现工作表按指定表头自动分表
来源: 阅读:823 次 日期:2016-06-30 11:30:28
温馨提示: 小编为您整理了“VBS实现工作表按指定表头自动分表”,方便广大网友查阅!

下面的VBS脚本就是实现的工作表按指定表头(由用户选择)自动分表功能。需要的朋友只要将要操作的工作表拖放到脚本文件上即可轻松实现工作表分表

在我们实际工作中经常遇到将工作表按某一表头字段分开的情况,我们一般的做法是先按指定表头排序然后分段复制粘贴出去,不但麻烦还很容易搞错。

下面的VBS脚本就是实现的工作表按指定表头(由用户选择)自动分表功能。需要的朋友只要将要操作的工作表拖放到脚本文件上即可轻松实现工作表分表(暂时只适用于xp系统):

代码如下:

'拖动工作表至VBS脚本实现按指定表头自动分表

On Error Resume Next

If WScript.Arguments(0) = "" Then WScript.Quit

Dim objExcel, ExcelFile, MaxRows, MaxColumns, SHCount

ExcelFile = WScript.Arguments(0)

If LCase(Right(ExcelFile,4)) <> ".xls" And LCase(Right(ExcelFile,4)) <> ".xls" Then WScript.Quit

Set objExcel = CreateObject("Excel.Application")

objExcel.Visible = False

objExcel.Workbooks.Open ExcelFile

'获取工作表初始sheet总数

SHCount = objExcel.Sheets.Count

'获取工作表有效行列数

MaxRows = objExcel.ActiveSheet.UsedRange.Rows.Count

MaxColumns = objExcel.ActiveSheet.UsedRange.Columns.Count

'获取工作表首行表头列表

Dim StrGroup

For i = 1 To MaxColumns

StrGroup = StrGroup & "[" & i & "]" & vbTab & objExcel.Cells(1, i).Value & vbCrLf

Next

'用户指定分表表头及输入性合法判断

Dim Num, HardValue

Num = InputBox("请输入分表表头的序号" & vbCrLf & StrGroup)

If Num <> "" Then

Num = Int(Num)

If Num > 0 And Num <= MaxColumns Then

HardValue = objExcel.Cells(1, Num).Value

Else

objExcel.Quit

Set objExcel = Nothing

WScript.Quit

End If

Else

objExcel.Quit

Set objExcel = Nothing

WScript.Quit

End If

'获取分表表头值及分表数

Dim ValueGroup : j = 0

Dim a() : ReDim a(10000)

For i = 2 To MaxRows

str = objExcel.Cells(i, Num).Value

If InStr(ValueGroup, str) = 0 Then

a(j) = str

ValueGroup = ValueGroup & str & ","

j = j + 1

End If

Next

ReDim Preserve a(j-1)

'创建新SHEET并以指定表头值命名

For i = 0 To UBound(a)

If i + 2 > SHCount Then objExcel.Sheets.Add ,objExcel.Sheets("sheet" & i + 1),1,-4167

Next

For i = 0 To UBound(a)

objExcel.Sheets("sheet" & i + 2).Name = HardValue & "_" & a(i)

Next

'分表写数据

For i = 1 To MaxRows

For j = 1 To MaxColumns

objExcel.sheets(1).Select

str = objExcel.Cells(i,j).Value

If i = 1 Then

For k = 0 To UBound(a)

objExcel.sheets(HardValue & "_" & a(k)).Select

objExcel.Cells(i,j).Value = str

objExcel.Cells(1, MaxColumns + 1).Value = 1

Next

Else

objExcel.sheets(HardValue & "_" & objExcel.Cells(i,Num).Value).Select

If j = 1 Then x = objExcel.Cells(1, MaxColumns + 1).Value + 1

objExcel.Cells(x ,j).Value = str

If j = MaxColumns Then objExcel.Cells(1, MaxColumns + 1).Value = x

End If

Next

Next

For i = 0 To UBound(a)

objExcel.sheets(HardValue & "_" & a(i)).Select

objExcel.Cells(1, MaxColumns + 1).Value = ""

Next

objExcel.ActiveWorkbook.Save

objExcel.Quit

Set objExcel = Nothing

WScript.Echo "提示:对" & ExcelFile & "的分表操作完成"

更多信息请查看脚本栏目
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2025国考·省考课程试听报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map