最終行を下記の方法で取得して、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も見ています
-
あるあるbotに投稿したけど採用されなかったあるある募集
あるあるbotに投稿したけど採用されなかったあるあるをこちらに投稿してください
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
Excelの数式の効率化について
Excel(エクセル)
-
データチェックを行うエクセルマクロをおしえてほしい
Excel(エクセル)
-
Excelを無料で使うには? パソコン購入して、マイクロソフトに登録して そのままExcelがデスク
Excel(エクセル)
-
-
4
再質問です。マクロの修正箇所を教えてください。
Excel(エクセル)
-
5
とびとびの大量セルを選択したいのですが・・・
Excel(エクセル)
-
6
Excelの数値の小数点表示について質問です
Excel(エクセル)
-
7
【マクロ】顧客番号にて一致させ、情報を表へ上書きする為には
Excel(エクセル)
-
8
ある表にフィルターをかけて出てきた記号の個数を知りたいのですが、簡単な関数はないでしょうか?
Excel(エクセル)
-
9
Excel 1の位の数字で処理を分岐させたい
Excel(エクセル)
-
10
エクセルで数字の組み合わせを列記したい
Excel(エクセル)
-
11
【ExcelVBA】UTF-8(BOM無)でCSV保存するには?
Excel(エクセル)
-
12
ExcelVBAマクロで実行した時の疑問
Visual Basic(VBA)
-
13
【Excel】版が同じ事を示す番号を生成したい
Excel(エクセル)
-
14
【マクロ】functionプロシージャの、変数について
Excel(エクセル)
-
15
Excelの時刻の不思議
Excel(エクセル)
-
16
エクセルでの2項目比較および抽出方法について
Excel(エクセル)
-
17
他部署からもらう データで、 何かのシステムからダウンロードしてエクセルの貼り付けていると思ういます
Excel(エクセル)
-
18
【マクロ】Ifとwith ステートメントにて分からない部分があります
Excel(エクセル)
-
19
エクセル共有したが、アクセスできなくかった
Excel(エクセル)
-
20
【ExcelVBA】名前を付けて保存→PDF保存をマクロで実行できますか?
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・歩いた自慢大会
- ・許せない心理テスト
- ・字面がカッコいい英単語
- ・これ何て呼びますか Part2
- ・人生で一番思い出に残ってる靴
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・初めて自分の家と他人の家が違う、と意識した時
- ・単二電池
- ・チョコミントアイス
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
PS4コントローラーをPCでゲーム...
-
4Kの外部モニターに出力すると...
-
COBOLのMOVEで桁数が異なる場合
-
CRC16計算について
-
ListViewの複数選択について
-
RS232cデーターをエクセルに落とす
-
MMDでavi出力が出来ない
-
Windows Formアプリからコンソ...
-
スマホのバッテリー消費につい...
-
プログラムについての質問です...
-
中国の電子レンジの火力は何ワ...
-
VBAのExecメソッドで画面を非表...
-
cout と cerrの違い
-
ACCESS VBA テーブルの値のオ...
-
AccessでPDFを複数ファイルにし...
-
センサーのタンパー出力について
-
無線とかアンテナに関しの質問...
-
coutで出力した文字を消去する...
-
コンセントの電力は入力と出力...
-
エクセルVBAでテキストファイル...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
PS4コントローラーをPCでゲーム...
-
4Kの外部モニターに出力すると...
-
MMDでavi出力が出来ない
-
プログラムについての質問です...
-
COBOLのMOVEで桁数が異なる場合
-
cout と cerrの違い
-
コンセントの電力は入力と出力...
-
スマホのバッテリー消費につい...
-
アクセスでエクセルに出力する...
-
PC電源は、出力DC12VとDC5Ⅴで...
-
Windows Formアプリからコンソ...
-
ACCESS クエリ→フォーム...
-
VBAのExecメソッドで画面を非表...
-
printfの書式%.*s
-
無線とかアンテナに関しの質問...
-
【ExcelVBA】最終行の取得で困...
-
ACCESSからExcelへエクスポート...
-
Accessのテーブルからcsv出力す...
-
CRC16計算について
-
Excel VBAで値を変えながら、pd...
おすすめ情報