一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術(shù)及教程分享平臺!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - VBS - VBS實(shí)現(xiàn)工作表按指定表頭自動分表

VBS實(shí)現(xiàn)工作表按指定表頭自動分表

2020-08-09 17:43VBS教程網(wǎng) VBS

下面的VBS腳本就是實(shí)現(xiàn)的工作表按指定表頭(由用戶選擇)自動分表功能。需要的朋友只要將要操作的工作表拖放到腳本文件上即可輕松實(shí)現(xiàn)工作表分表

在我們實(shí)際工作中經(jīng)常遇到將工作表按某一表頭字段分開的情況,我們一般的做法是先按指定表頭排序然后分段復(fù)制粘貼出去,不但麻煩還很容易搞錯。

下面的VBS腳本就是實(shí)現(xiàn)的工作表按指定表頭(由用戶選擇)自動分表功能。需要的朋友只要將要操作的工作表拖放到腳本文件上即可輕松實(shí)現(xiàn)工作表分表(暫時(shí)只適用于xp系統(tǒng)):

復(fù)制代碼 代碼如下:


'拖動工作表至VBS腳本實(shí)現(xiàn)按指定表頭自動分表
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總數(shù)
SHCount = objExcel.Sheets.Count
'獲取工作表有效行列數(shù)
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
'獲取分表表頭值及分表數(shù)
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)
'創(chuàng)建新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
'分表寫數(shù)據(jù)
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 & "的分表操作完成"

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 美女扒开腿让男人桶爽动态图片 | 久久国产加勒比精品无码 | 草久久网 | 日产2021免费一二三四区 | 99久久精品99999久久 | 美女把小内内脱个精光打屁屁 | 亚洲精品一区波多野结衣 | 欧美激情精品久久久久久不卡 | 丝袜兔女郎被啪在线观看91 | 精品人伦一区二区三区潘金莲 | 欧美激情综合 | 免费标准高清看机机桶机机 | 丰满岳乱妇在线观看视频国产 | 国产欧美一区二区三区免费看 | 果冻传媒在线播放1 | 久久re热在线视频精69 | 欧美一区二区三 | 91桃色网站 | 999精品视频这里只有精品 | 久久久久久久久a免费 | 久久三级视频 | 精品国产一区二区三区久 | 亚洲AV无码一区二区三区乱子伦 | 乳女教师欲乱动漫无修版动画3d | 非洲一级毛片又粗又长aaaa | 经典三级四虎在线观看 | 调教小龙女 | 国产福利在线观看永久视频 | 国产精品天天影视久久综合网 | 欧美高清videosex极品 | 百合互慰吃奶互揉漫画 | 久久精品中文字幕 | 国产麻豆传媒在线观看 | 欧美国产合集在线视频 | 久久精品热在线观看30 | 国产精品探花一区在线观看 | 亚洲国产精品一区二区久久 | 国产精品自在线拍 | 青草悠悠视频在线观看 | 热久久99精品这里有精品 | 欧美专区在线播放 |