ExcelマクロVBA練習問題解答
練習問題26(全シート処理とハイパーリンク)回答

Excelマクロ練習問題集、エクセルVBAの学習教材
最終更新日:2015-10-22

練習問題26(全シート処理とハイパーリンク)回答

練習問題26の回答ページです、



問題

現在のブックの先頭に新規シートを追加し、
既存シートのシート名一覧をハイパーリンク付きで作成して下さい。

※全シートのハイパーリンク付き一覧を先頭シートに作成します。

  これは、実務においても非常に良く発生する要求です。


では、お考えください。

すぐに回答を見ずに、必ず自力で書けるとこまででも良いので書きましょう。


・・
・・・
・・・・
・・・・・

当サイトのコンテンツ

ExcelマクロVBA入門
マクロの記録で覚えるVBA

ここで、じっくり勉強して下さい。



・・
・・・
・・・・
・・・・・




では、回答です。

Sub 練習問題26_1()
  Dim i As Long
  Dim j As Long
  Dim ws As Worksheet
  Set ws = Worksheets.Add(Before:=Worksheets(1))
  j = 1
  For i = 2 To Worksheets.Count
    ws.Hyperlinks.Add Anchor:=ws.Cells(j, 1), Address:="", _
             SubAddress:=Worksheets(i).Range("A1").Address(external:=True), _
             TextToDisplay:=Worksheets(i).Name


    ws.Hyperlinks.Add Anchor:=ws.Cells(j, 1), Address:="", _
             SubAddress:="'" & Worksheets(i).Name & "'!A1", _
             TextToDisplay:=Worksheets(i).Name
    j = j + 1
  Next
End Sub
Sub 練習問題26_2()
  Dim i As Long
  Dim j As Long
  Dim ws As Worksheet
  Worksheets.Add Before:=Sheets(1)
  j = 1
  For Each ws In Worksheets
    With Worksheets(1)
      If ws.Index > 1 Then
        .Hyperlinks.Add Anchor:=.Cells(j, 1), Address:="", _
                SubAddress:=ws.Range("A1").Address(external:=True), _
                TextToDisplay:=ws.Name

        .Hyperlinks.Add Anchor:=.Cells(j, 1), Address:="", _
                SubAddress:="'" & ws.Range("A1").Name & "'!A1", _
                TextToDisplay:=ws.Name
        j = j + 1
      End If
    End With
  Next
End Sub


2通り紹介しましたが、


このような場合にFor Eachを使うと、
どうしても2番目のシートからという記述がめんどうになってしまいます。

前後に他の処理がある場合は、適宜どちらで書くか判断して下さい。

また、
SubAddress:=Worksheets(i).Range("A1").Address(external:=True)
これは
SubAddress:="'" & Worksheets(i).Name & "'!A1"
このように書く事も出来ます。
この場合は、
シングルクォーテーション(')を忘れずに付ける
ようにしましょう。
シングルクォーテーション(')を忘れると、
シート名に空白やカナ記号等があると、正しくハイパーリンクが付きません。

※訂正
 SubAddress:=Worksheets(i).Range("A1").Address(external:=True)
 この場合、ブック名が入ってしまうため、別名保存でリンク切れを起こします。
 SubAddress:="'" & Worksheets(i).Name & "'!A1"
 こちらを使うようにして下さい。


これは、実務においても非常に良く発生しますので、さくっと書けるようにしておきましょう。





同じテーマ「マクロVBA練習問題解答」の記事

練習問題19(総合練習1)回答
練習問題20(総合練習2)回答
練習問題21(総合練習3)回答
練習問題22(総合練習4)回答
練習問題23(総合練習5)回答
練習問題24(再帰呼出し)回答
練習問題25(各種VBA関数)回答
練習問題26(全シート処理とハイパーリンク)回答
練習問題27(データ分割し別ブック保存)回答
練習問題28(シートを別ブックにして値のみにする)回答
練習問題29(ロット引き当て)回答

新着記事NEW ・・・新着記事一覧を見る

エクセルの日付と時刻のまとめ|エクセル関数超技(3月6日)
Excelシートの複雑な計算式を解析するVBA|VBAサンプル集(2月18日)
VBAクラスの作り方:独自Rangeっぽいものを作ってみた|VBA技術解説(2月16日)
VBAクラスの作り方:列名のプロパティを自動作成する|VBA技術解説(2月14日)
VBAクラスの作り方:列名の入力支援と列移動対応|VBA技術解説(2月11日)
クラスを使って他ブックのイベントを補足する|VBA技術解説(2月6日)
Excelアドインの作成と登録について|VBA技術解説(2月3日)
参照設定、CreateObject、オブジェクト式の一覧|VBA技術解説(1月20日)
VBAでファイルを規定のアプリで開く方法|VBA技術解説(1月20日)
ドキュメントプロパティ(BuiltinDocumentProperties,CustomDocumentProperties)|VBA技術解説(1月19日)

アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.RangeとCellsの使い方|ExcelマクロVBA入門
4.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
5.変数とデータ型(Dim)|ExcelマクロVBA入門
6.マクロって何?VBAって何?|ExcelマクロVBA入門
7.とにかく書いて見よう(Sub,End Sub)|VBA入門
8.繰り返し処理(For Next)|ExcelマクロVBA入門
9.セルに文字を入れるとは(Range,Value)|VBA入門
10.ひらがな⇔カタカナの変換|エクセル基本操作



  • >
  • >
  • >
  • 練習問題26(全シート処理とハイパーリンク)回答

    このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


    記述には細心の注意をしたつもりですが、
    間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
    なお、掲載のVBAコードは自己責任で使ってください。万一データ破損等の損害が発生しても責任は負いません。






    このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。

    本文下部へ