
エクセルにデータを表示させて印刷するときに、
一続きのデータがページをまたいでしまうのですが、
またいだ時にページの一番はじめに、データの項目を表示させたいと思っています。
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で質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
EXCEL-VBAで印刷時のページ番号を取得したい
Excel(エクセル)
-
EXCEL、マクロ-改ページ行番号の取得方法を教えてください
Visual Basic(VBA)
-
A1セルにアクティブセルのページ数を入力したい
Excel(エクセル)
-
-
4
エクセルの最終ページだけを自動印刷
Excel(エクセル)
-
5
印刷時、改ページごとの下枠にのみ罫線を引きたい
Excel(エクセル)
-
6
Excel VBA あるセルでENTERを押すと特定のセルへ移動したい
Excel(エクセル)
-
7
マルチページで現在開いているページの確認
Visual Basic(VBA)
-
8
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
9
<EXCEL>ページ最後の行の罫線設定
Excel(エクセル)
-
10
ユーザーフォームを表示中にシートの操作をさせるには
Excel(エクセル)
-
11
エクセルの行タイトルを特定のページにつけたい。
Excel(エクセル)
-
12
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
13
【Excel】マクロでページを追加することはできますか?
Excel(エクセル)
-
14
コピーしたファイルのマクロを実行すると前のファイルが開く
Access(アクセス)
-
15
Excelのセルにユーザー名を表示する方法
Excel(エクセル)
-
16
VBAで印刷ページ最終行にページ計表示印刷したい
Visual Basic(VBA)
-
17
エクセルでページ数をあるセルに表示させたい
Excel(エクセル)
-
18
EXCEL/VBA 変数の値をクリップボードにコピーする方法
Visual Basic(VBA)
-
19
マクロ 実行ボタンを押さずに常に実行
Excel(エクセル)
-
20
マクロ セルに入力されたシートを選択する
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
DataGrdViewに関連付けたデータ...
-
JSPとサーブレットを使用した勤...
-
.NET SqlDataReader のレコー...
-
VBSやVBAでXMLファイルを読み込...
-
【ASP.NET MVC】一覧編集画面
-
ACCESSのVBAで[Split]について
-
VBA ピボットテーブル自動更新
-
VB.NETで DataRow()を利用して...
-
特定のセルが空白だったら、そ...
-
Accessのクエリで、replace関数...
-
VBAで自動集計(特定セルコピー...
-
access コンボボックス初期表示...
-
VBA初心者です。結合セルを保持...
-
データ数をカウントしたいのですが
-
セルの結果でマクロ実行
-
”戻り値”が変化したときに、マ...
-
VBA:小数点以下の数字を取得で...
-
screenupdatingが機能しなくて...
-
エクセルで、絶対値の平均を算...
-
VB.NETでコンボボックスの1行目...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
DataGrdViewに関連付けたデータ...
-
【Excel VBA】先頭の「0」飛び...
-
Listviewのデータを上から順番...
-
VB.net CrystalReportでプロジ...
-
.NET SqlDataReader のレコー...
-
GridViewにバインドせずにデー...
-
DataGridViewで表示に制限をつ...
-
GASでスプレッドシートの一番上...
-
C# データ配列から画像を作成す...
-
VBA ピボットテーブル自動更新
-
MSFlexGridのデータ表示位置の設定
-
JSPとサーブレットを使用した勤...
-
VBAでページ番号、ページ最終行...
-
【ASP.NET MVC】一覧編集画面
-
スプレッドシート 一括でQRコー...
-
ListViewで条件によって表示を...
-
C# ニコニコ動画API getthumbinfo
-
VBAで表に1つでも入ってたら取...
-
ACCESSのVBAで[Split]について
-
Q横並びデータを縦並びに変更
おすすめ情報