Excel VBA提取目錄

用Excel VBA制作表格目錄

說(shuō)明:當(dāng)Excel工作簿有很多表格時(shí),或者為了操作管理的便捷,我們需要提取表格的目錄來(lái)使表格更方便的使用监氢。以下是個(gè)人寫的VBA代碼,其實(shí)已經(jīng)有很多Excel工具箱有提取目錄的功能藤违,我自己寫代碼一是個(gè)人的興趣愛(ài)好浪腐,二是我需要增強(qiáng)自己的編程能力,這些代碼可分享供大家使用顿乒,但最主要的是寫給真正懂的人看议街,寫給想學(xué)VBA的童鞋看,也希望高手們能指出不足之處淆游,能改進(jìn)之處傍睹。

'---------------------------------------------------------
' Procedure : 提取目錄
' Author    : 俊學(xué)之道
' Purpose   : 創(chuàng)建目錄并增加超鏈接
' Date      : 2015-7-16
' Place     : 廈門
'---------------------------------------------------------
Sub 提取目錄()
    On Error Resume Next '忽略錯(cuò)誤
    Application.DisplayAlerts = False '取消提示警告
    Application.ScreenUpdating = False '取消屏幕更新
    Sheets("目錄").Delete '如果有目錄表格便先刪除
    
    '調(diào)用過(guò)程(注意:如果表格有圖片,插入的形狀犹菱,藝術(shù)字,剪貼畫吮炕,OLE對(duì)象都將被刪除腊脱,請(qǐng)謹(jǐn)慎使用)
    Call 刪除工作簿的所有shape對(duì)象 '調(diào)用過(guò)程
    
    '增加一個(gè)表格并重命名為目錄,目錄表格的代碼名稱序號(hào)是最大的
    Worksheets.Add before:=Worksheets(1) '第一個(gè)標(biāo)簽名前增加新表格
    ActiveSheet.Name = "目錄" '增加的新表格重命名為目錄
        
    Dim i As Integer
        For i = 1 To Sheets.Count - 1 '由于增加了目錄表格使工作表數(shù)目多了一個(gè)龙亲,需要減去一個(gè)
            'A列編號(hào)
            Cells(1, 1) = "編號(hào)"
            Cells(i + 1, 1) = i
            'B列目錄
            Cells(1, "B") = "目錄"
            Cells(i + 1, "B") = Worksheets(i + 1).Name '每個(gè)工作表的名稱賦值到目錄頁(yè)的B列
        Next
    
    '凍結(jié)窗格
     With ActiveWindow
            .SplitColumn = 4
            .SplitRow = 1
     End With
    ActiveWindow.FreezePanes = 1 '1或true凍結(jié)陕凹,0取消凍結(jié)
    
    Call 增加超鏈接 '調(diào)用過(guò)程
    Application.ScreenUpdating = True '恢復(fù)屏幕更新
    Application.DisplayAlerts = True '恢復(fù)提示警告
End Sub

'---------------------------------------------------------
'以下為將要調(diào)用的兩個(gè)過(guò)程
'---------------------------------------------------------
'過(guò)程1:刪除工作簿的所有shape對(duì)象
'---------------------------------------------------------
Sub 刪除工作簿的所有shape對(duì)象()
    For Each Sht In Worksheets
        Sht.Activate
        ActiveSheet.Shapes.SelectAll '選中當(dāng)前工作表的所有shape對(duì)象
        Selection.Delete
    Next
End Sub

'---------------------------------------------------------
'過(guò)程2:增加超鏈接
'---------------------------------------------------------
Sub 增加超鏈接() '這個(gè)過(guò)程應(yīng)該還有改進(jìn)簡(jiǎn)化的空間,現(xiàn)在水平不足鳄炉,將來(lái)繼續(xù)改進(jìn)
        On Error Resume Next '忽略錯(cuò)誤
            i = 1
        For Each Sht In Worksheets
        
             'a.目錄頁(yè)增加超鏈接地址
            Sheets("目錄").Hyperlinks.Add Anchor:=Sheets("目錄").Cells(i + 1, 2), Address:="", SubAddress:="'" & Worksheets(i + 1).Name & "'" & "!A1"
            
            i = i + 1
            
            Sht.Activate '遍歷工作表使每個(gè)工作表成為當(dāng)前窗口
            ActiveSheet.Shapes.AddTextbox(msoTextOrientationHorizontal, 700, 20, 100, 30).Select '在每個(gè)當(dāng)前工作表增加Textbox
            Selection.ShapeRange.TextFrame2.VerticalAnchor = msoAnchorMiddle
            Selection.ShapeRange(1).TextFrame2.TextRange.Characters.Text = "返回目錄"
            Selection.ShapeRange.Line.Visible = msoFalse '無(wú)形狀輪廓
            Selection.ShapeRange.Fill.Visible = msoFalse '無(wú)形狀填充
            
            With Selection.ShapeRange(1).TextFrame2.TextRange.Characters(1, 4).Font.Line
                .Visible = msoTrue                   '有文本輪廓
                .ForeColor.RGB = RGB(0, 112, 192)    '文本輪廓的顏色
            End With
           
            Selection.ShapeRange(1).TextFrame2.TextRange.Characters(1, 4).ParagraphFormat.Alignment = msoAlignCenter
            Selection.ShapeRange(1).TextFrame2.TextRange.Characters(1, 4).Font.Size = 15
            
            'b.Textbox增加超鏈接至目錄頁(yè)
            ActiveSheet.Hyperlinks.Add Anchor:=Selection.ShapeRange.Item(1), Address:="", SubAddress:="'目錄'!A1"
            ActiveSheet.Cells(1, 1).Select '定位在A1單元格
        Next Sht
        
        Sheets("目錄").Select '定位在目錄頁(yè)
        ActiveSheet.Shapes.SelectAll '選中當(dāng)前工作表的所有shape對(duì)象
        Selection.Delete '刪除選中的多余shape對(duì)象
End Sub

以下為提取目錄后的效果圖:


效果圖1

表格里有返回目錄的按鈕:


效果圖2
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末杜耙,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子拂盯,更是在濱河造成了極大的恐慌佑女,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,907評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件谈竿,死亡現(xiàn)場(chǎng)離奇詭異团驱,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)空凸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門嚎花,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人呀洲,你說(shuō)我怎么就攤上這事紊选√渲梗” “怎么了?”我有些...
    開封第一講書人閱讀 164,298評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵兵罢,是天一觀的道長(zhǎng)族壳。 經(jīng)常有香客問(wèn)我,道長(zhǎng)趣些,這世上最難降的妖魔是什么仿荆? 我笑而不...
    開封第一講書人閱讀 58,586評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮坏平,結(jié)果婚禮上拢操,老公的妹妹穿的比我還像新娘。我一直安慰自己舶替,他們只是感情好令境,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,633評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著顾瞪,像睡著了一般舔庶。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上陈醒,一...
    開封第一講書人閱讀 51,488評(píng)論 1 302
  • 那天惕橙,我揣著相機(jī)與錄音,去河邊找鬼钉跷。 笑死弥鹦,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的爷辙。 我是一名探鬼主播彬坏,決...
    沈念sama閱讀 40,275評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼膝晾!你這毒婦竟也來(lái)了栓始?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,176評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤血当,失蹤者是張志新(化名)和其女友劉穎幻赚,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體歹颓,經(jīng)...
    沈念sama閱讀 45,619評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡坯屿,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,819評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了巍扛。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片领跛。...
    茶點(diǎn)故事閱讀 39,932評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖撤奸,靈堂內(nèi)的尸體忽然破棺而出吠昭,到底是詐尸還是另有隱情喊括,我是刑警寧澤,帶...
    沈念sama閱讀 35,655評(píng)論 5 346
  • 正文 年R本政府宣布矢棚,位于F島的核電站郑什,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏蒲肋。R本人自食惡果不足惜蘑拯,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,265評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望兜粘。 院中可真熱鬧申窘,春花似錦、人聲如沸孔轴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)路鹰。三九已至贷洲,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間晋柱,已是汗流浹背优构。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留趣斤,地道東北人俩块。 一個(gè)月前我還...
    沈念sama閱讀 48,095評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像浓领,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子势腮,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,884評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 1.1 VBA是什么 直到90年代早期,使應(yīng)用程序自動(dòng)化還是充滿挑戰(zhàn)性的領(lǐng)域.對(duì)每個(gè)需要自動(dòng)化的應(yīng)用程序,人們不得...
    浮浮塵塵閱讀 21,745評(píng)論 6 49
  • 自從2014年開通[完美Excel]微信公眾號(hào)以來(lái)联贩,堅(jiān)持分享已經(jīng)學(xué)習(xí)到的Excel和VBA知識(shí)和心得,目前已分享文...
    完美Excel閱讀 8,308評(píng)論 6 69
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,129評(píng)論 25 707
  • 本例為設(shè)置密碼窗口 (1) If Application.InputBox(“請(qǐng)輸入密碼:”) = 1234 Th...
    浮浮塵塵閱讀 13,648評(píng)論 1 20
  • 晨起捎拯,記昨夜夢(mèng)泪幌,深覺(jué)有危機(jī)。余以讀書考試署照,乃得入學(xué)祸泪,有閒暇則以求索宇宙人生。若不能讀書建芙,則余與鄉(xiāng)里之人何異没隘。近覺(jué)有...
    寒窗寄傲生閱讀 200評(píng)論 0 0