
No.3ベストアンサー
- 回答日時:
こんにちは。
もしかしたら、その表というのは、アウトラインと集計と複合的に出来ていませんか?
先ほど、何度も試してみて、集計だけだと思い込んでいたのです。質問を読み違えていました。そもそも、私が前回の質問が印象に残っていたのが原因なのですが。確かに、手作業ではややこしく面倒です。
もしそうだとすると、こうなるのでしょうね。
j =2
' On Error Resume Next 'エラーが発生するようなら、これを入れてください。
With ActiveSheet
.Outline.ShowLevels rowLevels:=0, columnLevels:=j
End With
Range("A1").Select
アウトラインをどのように作ったかは別として、2以上を入れればよいのではないかと思っています。途中、ピボットテーブルもどうかと思ったのですが、それもできないし、こういうのは、初めてです。うまくいくかどうか・・・・。
ありがとうございます。
前回の回答でOKです。読み違えてはいませんよ。
特定のアウトラインをいじりたいので前回ので問題は解決しています。
お手数おかけしました。
で、rowsは列を指定しますが、行をいじりたい場合なんと書けばよいかわかりませんか。
No.4
- 回答日時:
こんにちは。
今、ShowDetail と .Outline.ShowLevels と両方を試してみました。
ShowDetail は、列に対しては、なぜか、VBAメソッド側は、エラーが発生します。理由は良く分かりません。
やはり、列指定の場合は、以下のように、Ver.4 マクロ関数を使わざるを得ませんでした。
ShowDetail の場合は、列番号を指定しなくてはなりません。つまり、シートの「+」「-」をクリックするのと同じことです。
Dim i As Integer
'列の表示・非表示
i = 10 '列数を指定
ret = Application.ExecuteExcel4Macro("SHOW.DETAIL(2," & i & ")")
End Sub
しかし、#3 で示した方法なら、ワークシートの一番左上の数の、数字のレベルによって変化するはずです。通常なら、1 で、すべての列が非表示で合計欄だけになり、2 .... と続きます。#3のコードを手直ししてみました。
'標準モジュールのみ
Sub TestShowLevel()
Dim i As Integer
Dim j As Integer
Dim r As Range
Static k As Integer
On Error Resume Next
With ActiveSheet
Set r = Range("A1").CurrentRegion
i = r.Rows(1).SpecialCells(xlCellTypeVisible).Count
j = r.Rows(1).Cells.Count
If j - i > 0 Then
k = k + 1
Else
k = 1
End If
.Outline.ShowLevels rowLevels:=0, columnLevels:=k
End With
End Sub
No.2
- 回答日時:
こんばんは。
たぶん、行に対して、アウトラインを展開しているなら、列は、1でよいと思いますね。
VBAメソッド側は、そういう違いが出ません。
なお、i は、"*集計"のところの行を指定してください。
マクロ関数側のret は、ダミーです。エラーは返ることはないはずですが、一応、置いておきました。必要なければ取ってもかまいません。
'マクロ関数
Sub Test1()
Dim ret As Variant
Dim i As Long
i = 3
ret = Application.ExecuteExcel4Macro("SHOW.DETAIL(1," & i & ")")
End Sub
'VBA メソッド
Sub Test2()
Dim i As Long
i = 3
ActiveSheet.Rows(i).ShowDetail = Not ActiveSheet.Rows(i).ShowDetail
End Sub
ありがとうございます。できました。
アウトライン展開は行、列でしています。
ちなみに参考までに。。。
行は
ActiveSheet.Rows(i).ShowDetail。。。
でできることがわかりましたが、列の場合rowsをcolumnsに変えてみましたが反応しません。
見た目的にVBAメソッドに書いてある関数のほうがきれいなのでできれば使いたいです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
今、見られている記事はコレ!
-
弁護士が解説!あなたの声を行政に届ける「パブリックコメント」制度のすべて
社会に対する意見や不満、疑問。それを発信する場所は、SNSやブログ、そしてニュースサイトのコメント欄など多岐にわたる。教えて!gooでも「ヤフコメ民について」というタイトルのトピックがあり、この投稿の通り、...
-
弁護士が語る「合法と違法を分けるオンラインカジノのシンプルな線引き」
「お金を賭けたら違法です」ーーこう答えたのは富士見坂法律事務所の井上義之弁護士。オンラインカジノが違法となるかどうかの基準は、このように非常にシンプルである。しかし2025年にはいって、違法賭博事件が相次...
-
釣りと密漁の違いは?知らなかったでは済まされない?事前にできることは?
知らなかったでは済まされないのが法律の世界であるが、全てを知ってから何かをするには少々手間がかかるし、最悪始めることすらできずに終わってしまうこともあり得る。教えてgooでも「釣りと密漁の境目はどこです...
-
カスハラとクレームの違いは?カスハラの法的責任は?企業がとるべき対応は?
東京都が、客からの迷惑行為などを称した「カスタマーハラスメント」、いわゆる「カスハラ」の防止を目的とした条例を、全国で初めて成立させた。条例に罰則はなく、2025年4月1日から施行される。 この動きは自治体...
-
なぜ批判コメントをするの?その心理と向き合い方をカウンセラーにきいた!
今や生活に必要不可欠となったインターネット。手軽に情報を得られるだけでなく、ネットを介したコミュニケーションも一般的となった。それと同時に顕在化しているのが、他者に対する辛らつな意見だ。ネットニュース...
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「段」と「行」の違いがよくわ...
-
エクセルで離れた列を選択して...
-
VLOOKUPの列番号の最大は?
-
ListViewで列を指定して表示さ...
-
LEFT関数とIF関数の組み合わせ...
-
列方向、行方向の定義
-
VBAで重複データを合算したい(...
-
エクセルで最初の行や列を開け...
-
VBA 指定した列にある日時デー...
-
最近急にVBAの処理速度が遅くな...
-
リストからデータを紐付けしたい
-
データシートビューのタイトル...
-
エクセルマクロPrivate Subを複...
-
Alt+Shift+↑を一括で行うには、...
-
エクセルの行を65536以上に増や...
-
VBAで別ブックの列を検索し、該...
-
EXCELを最大にて開いた際、特定...
-
CSVファイルの「0落ち」にVBA
-
エクセル マクロ 範囲の値を上...
-
エクセル マクロ 範囲指定で...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「段」と「行」の違いがよくわ...
-
エクセルで離れた列を選択して...
-
LEFT関数とIF関数の組み合わせ...
-
VLOOKUPの列番号の最大は?
-
VBA 指定した列にある日時デー...
-
Excelの行数、列数を増やしたい...
-
エクセルのソートで、数字より...
-
列方向、行方向の定義
-
VBAで別ブックの列を検索し、該...
-
エクセル マクロ 範囲指定で...
-
CSVファイルの「0落ち」にVBA
-
エクセルマクロPrivate Subを複...
-
エクセルで最初の行や列を開け...
-
最近急にVBAの処理速度が遅くな...
-
VBA
-
Excel文字列一括変換
-
エクセルで複数列の検索をマク...
-
エクセル マクロ 範囲の値を上...
-
横軸を日付・時間とするグラフ化
-
Alt+Shift+↑を一括で行うには、...
おすすめ情報