エクセルにデータを表示させて印刷するときに、
一続きのデータがページをまたいでしまうのですが、
またいだ時にページの一番はじめに、データの項目を表示させたいと思っています。
PrintTitleRowsを使用しようと思いましたが、
データの項目→データ、データの項目→データというようにエクセルシートに表示されているため、もし、丁度ページが変わったときにうまくデータの項目が次のページの1列目にくるとデータの項目がダブってしまい、使用することができません。
他の方法を考えてみたのですが、その方法では現在のページ番号を取得する方法か現在のページの最終行(データが最終行に入力されていない場合も含む)を取得する方法を知らなくては実現することができません。
いろいろ調べたのですが、見つからず、このような方法がないのかもしれません。
うまく状況が説明できずすみません。
もしご存知の方がお見えになりましたら教えてください。
また、何か他によい方法をご存知の方がお見えになりましたら教えてください。
No.2ベストアンサー
- 回答日時:
ページの先頭に表題や項目(列)見出しを入れる場合
(1)エクセルのPrintTitleRowsを使う
この場合は最初以外は項目見だしをいれないのが普通でしょう。質問のケースはこれを入れていると言うことですか。
そのため邪魔になると言うことでしょうか。
であれば削除するか、非表示にするのが手でしょう。
項目見出しを何かの文言・印でプログラムで割り出せるなら、その行をプログラムで非表示にすることも出来るでしょう。
(2)PageBreakで改ページし、改ページ後に
項目見出しを(手動でということになる)いれる。
と言うか項目見出しの行の前で改ページを入れる。
紙は多少無駄が起こるかもしれない。
(3)VBAでPrintAreaを別途編集し直し
項目見出しを最上部にセットする。
すると普通は毎ページ「一定行数」+見だし行数となろう。その場合も中間の項目見だしは邪魔になる。
(4)(2)の場合PageBreakの位置をVBAで
取得し、その後に項目見だしを印刷し、明細行を打てばよいが、Printoutでは、改ページしてしまうので不可能。行印刷して改ページしないメソッドが判れば可能。
>現在のページの最終行(データが最終行に入力されていない場合も含む)を取得する方法
これはプリンタの動作の最終行と言う情報をシステムに送らせないといけないが、VBAレベルでは多分不可能でしょう。APIでも難しいのでは。プリント動作はプリンタドライバに任せているのだと思う。
様々な方法を教えてくださり、ありがとうございます。
項目の上に表示データごとにことなるもう一つの見出しがつくため項目を非表示にすることは難しいと思いますが、それぞれ教えてくださった方法を試して見たいと思います。
ありがとうございました。
No.1
- 回答日時:
私なら印刷を以下のようにマクロ化します。
1)2番目以降のデータ項目の行を非表示にする
2)1番目のデータ項目をタイトル行にして印刷する
3)非表示にした行を表示に戻す。
現在のページ番号を直接知るのは、無理かもしれませんが、間接的にRangeオブジェクトのPageBreakプロパティかHPageBreak オブジェクト(VPageBreakも必要かもしれません)の位置の記録と集計を使えば可能じゃないかとは思います。
お答えいただき、ありがとうございます。
やはり現在のページ番号を直接知るのは無理なんですね。
この方法を試して見ます。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 【VBA】データを入力後に,同一シート内に履歴として転記するVBAコードを教えていただきたいです。 3 2022/11/16 01:37
- PHP php my adminより取り出したデータ表示 2 2022/06/15 11:56
- PHP PHP ページング データベース 1 2022/06/16 10:30
- Visual Basic(VBA) マクロについて(tatsumaru77さん見てください) 5 2023/06/07 17:51
- Excel(エクセル) エクセルの印刷範囲をページ単位で可変にする方法 3 2022/05/23 13:04
- Excel(エクセル) エクセルの散布図で新たに入力した値のデータラベルが空欄になる現象 1 2022/04/26 09:31
- Visual Basic(VBA) Selenium.ChromeDriverの使い方について 7 2022/09/22 06:43
- HTML・CSS htmlのデータをwebページみたいに見る方法 5 2023/06/23 17:47
- PHP 配列の値の更新方法について 1 2022/08/05 09:49
- Excel(エクセル) エクセルについて教えてください。 2 2023/06/14 11:11
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
EXCEL-VBAで印刷時のページ番号を取得したい
Excel(エクセル)
-
EXCEL、マクロ-改ページ行番号の取得方法を教えてください
Visual Basic(VBA)
-
VBAで印刷ページ最終行にページ計表示印刷したい
Visual Basic(VBA)
-
-
4
【Excel】マクロでページを追加することはできますか?
Excel(エクセル)
-
5
A1セルにアクティブセルのページ数を入力したい
Excel(エクセル)
-
6
Excelのマクロについて
Visual Basic(VBA)
-
7
<EXCEL>ページ最後の行の罫線設定
Excel(エクセル)
-
8
EXCEL VBAでHPageBreaks
Excel(エクセル)
-
9
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
10
エクセル VBA 印刷改ページ 行数設定
Excel(エクセル)
-
11
数式による空白を無視して最終行を取得するマクロ
Excel(エクセル)
-
12
vba 改ページカウントで不可解なエラーを回避したいのですが教えてください
Excel(エクセル)
-
13
マクロの「Rangeメソッドは失敗しました’Globalオブジェクト」エラーの解決方法について
Excel(エクセル)
-
14
【vba】指定範囲の中に任意の文字があるときの条件分岐
Excel(エクセル)
-
15
斜め罫線の判定 ExcelVBA
Excel(エクセル)
-
16
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
17
画像を削除したい(VBA)
Word(ワード)
-
18
VBAでループ内で使う変数名を可変にできないか。
Visual Basic(VBA)
-
19
VBAのコマンドボタンの文字列の改行方法は?
Visual Basic(VBA)
-
20
ファイル名を今日の日付、時刻で保存する
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
【Excel VBA】先頭の「0」飛び...
-
コンパイルエラーSubまたは...
-
.NET SqlDataReader のレコー...
-
VBAでページ番号、ページ最終行...
-
GASでスプレッドシートの一番上...
-
スプレッドシート 一括でQRコー...
-
Listviewのデータを上から順番...
-
DataGrdViewに関連付けたデータ...
-
MSFlexGridのデータ表示位置の設定
-
エクセルマクロ小数点桁数
-
コード側からDataGridの列を追...
-
C# データ配列から画像を作成す...
-
PDFメニューバーの右端にある(...
-
クラス内だけでhtmlデータをダ...
-
C# 一覧とデータテーブルを比較...
-
エクセルVBA、数式の入ったセル...
-
VBによる可変長ファイルの読み書き
-
ListViewで条件によって表示を...
-
XMLとは?
-
ExcelVBAを使って、値...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【Excel VBA】先頭の「0」飛び...
-
DataGrdViewに関連付けたデータ...
-
Listviewのデータを上から順番...
-
GASでスプレッドシートの一番上...
-
VBAでページ番号、ページ最終行...
-
.NET SqlDataReader のレコー...
-
GridViewにバインドせずにデー...
-
【ASP.NET MVC】一覧編集画面
-
ASP C# データベースから1行取得
-
MSFlexGridのデータ表示位置の設定
-
コンパイルエラーSubまたは...
-
C# データ配列から画像を作成す...
-
エクセルマクロ小数点桁数
-
DataGridViewで表示に制限をつ...
-
スプレッドシート 一括でQRコー...
-
GridViewを自動的にスクロール...
-
VB DataRepeaterにて条件で表示
-
DBへの重複更新を防ぐ方法について
-
GoogleEarthのKMLファイルでラ...
-
エクセルVBA、数式の入ったセル...
おすすめ情報