VBA100本ノック 47本目:Window操作
WorkbookのWindowオブジェクトを操作する問題です。
リボンの「表示」タブにある設定項目になります。
ツイートでの見やすさを考慮して、ブック・シート指定等を適宜省略しています。
出題
ブックの全ウィンドウの全シートに対して以下の処理を行ってください。
・A1セルを選択しA1セルが見える状態にする
・ズームを85%
・枠線を非表示
・表示を標準
・印刷の向き「横」
※全ウィンドウという点を忘れずに
※ブックは任意
罫線ではなく、表示の「目盛り線」のつもりで書いてしまいました。
これは、シートごとではなくウィンドウごとに存在します。
頂いた回答
解説
リボンの「表示」タブの設定です。
Windowは階層が複雑で理解しづらいと思います。
ApplicationにもWorkbookにもWindowsがありますが、今回はWorkbookの扱いです。
順にオブジェクトを辿ってみます。
Sub VBA100_47_01()
Dim wb As Workbook: Set wb = ThisWorkbook
Dim ws As Worksheet
Dim win As Window
Dim sv As Object
Application.ScreenUpdating = False
Application.PrintCommunication = False
For Each ws In wb.Worksheets
ws.PageSetup.Orientation = xlLandscape
Next
Application.PrintCommunication = True
For Each win In wb.Windows
win.Activate
For Each sv In win.SheetViews
If TypeName(sv) = "WorksheetView" Then
sv.Sheet.Activate
Application.Goto sv.Sheet.Range("A1"), True
sv.DisplayGridlines = False
win.View = xlNormalView
win.Zoom = 85
End If
Next
Next
Application.ScreenUpdating = True
End Sub
あまり使う事のない、SheetViews、WorksheetView、これらに行き当たります。
使い慣れないオブジェクトは階層を辿る時にも迷ってしまいますね。
使い慣れたWorksheetをActivateしたほうが扱いやすいかもしれません。
Sub VBA100_47_02()
Dim wb As Workbook: Set wb = ThisWorkbook
Dim ws As Worksheet
Dim win As Window
Application.ScreenUpdating = False
Application.PrintCommunication = False
For Each ws In wb.Worksheets
ws.PageSetup.Orientation = xlLandscape
Next
Application.PrintCommunication = True
For Each win In wb.Windows
win.Activate
For Each ws In wb.Worksheets
ws.Activate
Application.Goto ws.Range("A1"), True
With win
.DisplayGridlines = False
.View = xlNormalView
.Zoom = 85
End With
Next
Next
Application.ScreenUpdating = True
End Sub
A1選択にはApplication.Gotoを使いました。
スクロールはされますが非表示はそのままになります。
Windowは使用頻度が低い分はまりやすい気がします。
1度はVBAを書いて経験しておくと良いと思います。
補足はありません、VBAと参考ページを掲載しました。
補足
サイト内関連ページ
同じテーマ「VBA100本ノック」の記事
44本目:全テーブル一覧作成
45本目:テーブルに列追加
46本目:名前定義に使える文字
47本目:Window操作
48本目:配列と数値型
49本目:条件付き書式の判定
50本目:トリボナッチ数列
51本目:シート一覧と印刷ページ数
52本目:複数シートの一括印刷
53本目:テーブルの扱いと年齢計算
54本目:シートのChangeイベント
新着記事NEW ・・・新着記事一覧を見る
VBA100本ノック 68本目:全テキストボックスの転記|VBA練習問題(1月16日)
VBA100本ノック 67本目:ComboBoxとListBox|VBA練習問題(1月15日)
VBA100本ノック 66本目:全サブフォルダからファイルを探す|VBA練習問題(1月13日)
VBA100本ノック 65本目:固定長テキスト出力|VBA練習問題(1月12日)
VBA100本ノック 64本目:リンクされた図(カメラ機能)|VBA練習問題(1月11日)
VBA100本ノック 63本目:複数シートの連結|VBA練習問題(1月9日)
VBA100本ノック 62本目:独自のZLOOKUP関数を作成|VBA練習問題(1月8日)
VBA100本ノック 61本目:「ふりがな」の取得と設定|VBA練習問題(1月6日)
VBA100本ノック 60本目:「株式会社」の表記ゆれ置換|VBA練習問題(1月5日)
VBA100本ノック 59本目:12ヶ月分のシートを四半期で分割|VBA練習問題(1月4日)
アクセスランキング ・・・ ランキング一覧を見る
1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.マクロって何?VBAって何?|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.繰り返し処理(For Next)|VBA入門
7.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
8.セルに文字を入れるとは(Range,Value)|VBA入門
9.とにかく書いてみよう(Sub,End Sub)|VBA入門
10.繰り返し処理(Do Loop)|VBA入門
- ホーム
- マクロVBA入門編
- VBA100本ノック
- 47本目:Window操作
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。