最終行を下記の方法で取得して、CSV出力するマクロを作ってます。
lastRow = shtData.Cells(shtData.Rows.Count, 1).End(xlUp).Row
↑この処理で、A列の最終行を取得してるのですが、
A列には、「=IF(C2="","",・・・・」が入っており、集計表自体は100行まであっても、
画面上に見えてるレコードが7行だったら7レコード分だけ出力したいのですが、
100行まるまる出力されてしまいます。(セルに関数が入っているだけでカウントされてしまう)
画面に数値が表示されている最終行を取得するにはどうしたら良いでしょうか?
A 回答 (4件)
- 最新から表示
- 回答順に表示
No.4
- 回答日時:
No.2さんの案(下記)に1票。
C列で最終列を取得する。
lastRow = shtData.Cells(shtData.Rows.Count, 3).End(xlUp).Row
C列に限らず、最終行にデータが入力されている列があるはず、だと思います。
代案
A列全体をコピーして最終列の右列に値で貼付けて、その列で最終行を取得する。
lastRow = shtData.Cells(shtData.Rows.Count, 貼り付けた列).End(xlUp).Row
貼り付けた列は消しても消さなくてもよいです。お好みで。
データ数にもよりますが、追加分による実行時間は0.1秒もかからないでしょう。
No.3
- 回答日時:
こんにちは
空白行のある対象範囲を取得する時に使う AutoFilter で・・・
With shtData
.Range("A1").AutoFilter 1, "<>"
r = .Range("A1").SpecialCells(xlLastCell).Row
c = .Range("A1").SpecialCells(xlLastCell).Column
.Range("A1").AutoFilter
間に空白行の存在する可能性を踏まえて
Open fileFllPath For Output Asの場合
For i = 1 To r
If .Cells(i, 1) <> "" Then
Print #1, Application.TextJoin(",", 0, .Cells(i, 1).Resize(1, c))
End If
Next
みたいになるのかな・・
でも
If Cells(i, 1) <> "" Thenを書くならば処理速度はともかく
lastRow = shtData.Cells(shtData.Rows.Count, 1).End(xlUp).Row
でも空白行を除き出力されますね・・・
範囲にlastRowを使って設定しているのかな
AutoFilterを使って
Range("A1").AutoFilter 1, "<>"
set r=Range("A1").CurrentRegion.SpecialCells(xlCellTypeVisible)
で範囲を取得し(Copyなどで)使う方法もアリかな?
色んなパターンをご教授いただきありがとうございます。
今回助かりましたし、次回も試せて大変助かりました。
ありがとうございました。
No.2
- 回答日時:
こんにちは
実際の表がどうなっているのか不明ですけれど・・
ご提示の計算式を見る限り、C列を参照しているようですので、A列ではなくC列の最終行を求めるのでは上手くいきませんか?
(C列が直接入力であろうと想像)
あるいは、表全体が関数等で作成されているという事でしょうか?
ご質問の文章通りに、「A列の空白以外の最終行」を求めたければ、No1様の回答の方法でも良いですし、どこかの空きセルに
=MAX(INDEX((A1:A100<>"")*ROW(A1:A100),))
を入力しておけば、そのセルの値を参照することでも得ることができます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
これ何て呼びますか Part2
あなたのお住いの地域で、これ、何て呼びますか?
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
Excelの数式の効率化について
Excel(エクセル)
-
再質問です。マクロの修正箇所を教えてください。
Excel(エクセル)
-
Excelを無料で使うには? パソコン購入して、マイクロソフトに登録して そのままExcelがデスク
Excel(エクセル)
-
-
4
データチェックを行うエクセルマクロをおしえてほしい
Excel(エクセル)
-
5
とびとびの大量セルを選択したいのですが・・・
Excel(エクセル)
-
6
Excelの数値の小数点表示について質問です
Excel(エクセル)
-
7
Excelの時刻の不思議
Excel(エクセル)
-
8
【マクロ】顧客番号にて一致させ、情報を表へ上書きする為には
Excel(エクセル)
-
9
ある表にフィルターをかけて出てきた記号の個数を知りたいのですが、簡単な関数はないでしょうか?
Excel(エクセル)
-
10
Excel 1の位の数字で処理を分岐させたい
Excel(エクセル)
-
11
他部署からもらう データで、 何かのシステムからダウンロードしてエクセルの貼り付けていると思ういます
Excel(エクセル)
-
12
【マクロ】Ifとwith ステートメントにて分からない部分があります
Excel(エクセル)
-
13
【ExcelVBA】UTF-8(BOM無)でCSV保存するには?
Excel(エクセル)
-
14
ExcelVBAマクロで実行した時の疑問
Visual Basic(VBA)
-
15
エクセルで数字の組み合わせを列記したい
Excel(エクセル)
-
16
【マクロ】functionプロシージャの、変数について
Excel(エクセル)
-
17
【Excel】版が同じ事を示す番号を生成したい
Excel(エクセル)
-
18
エクセルでの2項目比較および抽出方法について
Excel(エクセル)
-
19
エクセルでチェックボックスを一列にたくさんつくり、各行にリンク先のセルを設定する場合、どのようにした
Excel(エクセル)
-
20
自動入力で今月はMONTH(TODAY())で良いのですが、翌月はどのようにすれば良いでしょうか。
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【お題】絵本のタイトル
- ・【大喜利】世界最古のコンビニについて知ってる事を教えてください【投稿~10/10(木)】
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・ハマっている「お菓子」を教えて!
- ・最近、いつ泣きましたか?
- ・夏が終わったと感じる瞬間って、どんな時?
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
PS4コントローラーをPCでゲーム...
-
cout と cerrの違い
-
4Kの外部モニターに出力すると...
-
プログラムについての質問です...
-
スマホのバッテリー消費につい...
-
MMDでavi出力が出来ない
-
printfが!
-
ノイズを除去したい
-
Accessのテーブルからcsv出力す...
-
コンセントの電力は入力と出力...
-
VBAのExecメソッドで画面を非表...
-
VBAでIEを操作、ポップアップさ...
-
CRC16計算について
-
PowerShellのスクリプトでイベ...
-
エクセルVBAで1行単位のデータ...
-
FORTRAN で出力した文字の 左寄...
-
C#でアクセス権限の取得方法が...
-
VB6で 先頭00をつけたいです...
-
タッチパネルの特性
-
バッチファイル フォルダサイ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
PS4コントローラーをPCでゲーム...
-
4Kの外部モニターに出力すると...
-
MMDでavi出力が出来ない
-
プログラムについての質問です...
-
コンセントの電力は入力と出力...
-
cout と cerrの違い
-
COBOLのMOVEで桁数が異なる場合
-
VBAのExecメソッドで画面を非表...
-
アクセスでエクセルに出力する...
-
Windows Formアプリからコンソ...
-
VBAでテキスト出力時のスペース...
-
coutで出力した文字を消去する...
-
Accessのテーブルからcsv出力す...
-
スマホのバッテリー消費につい...
-
ACCESS クエリ→フォーム...
-
テキストファイルから特定の文...
-
ACCESSからExcelへエクスポート...
-
無線とかアンテナに関しの質問...
-
CRC16計算について
-
printfとputcharの違いは
おすすめ情報