お世話になります。
Cのセルが空白でなかったら、Aのセルに順番に数値を入力したいのですが
このコードを実行すると、画像右のようにCの空白部分で
Aの番号が飛んでしまいます。
左の画像のようにしたいのですが、どなたか手直しを
していただけないでしょうか。
よろしくお願いします。
Sub NO1()
Dim i As Long
i = 9
For i = 9 To 35
If Range("C" & i).Value = "" Then
Range("A" & i).Value = ""
Else
Range("A" & i).Value = i - 8
End If
Next
End Sub
No.1ベストアンサー
- 回答日時:
入力する番号を別変数に割り当てれば良いかと
一例です
Sub NO1()
Dim i As Long, n As Long
For i = 9 To 35
If Range("C" & i).Value = "" Then
Range("A" & i).Value = ""
Else
n = n + 1
Range("A" & i).Value = n
End If
Next
End Sub
No.6
- 回答日時:
こんばんは!
すでに色々回答は出ていますが・・・
わざわざVBAでなくてもNo.2さんの数式でできると思います。
A9セルに
=IF(C9="","",COUNTA(C$9:C9))
としてフィルハンドルで下へコピー!
C列に数式が入っていて、数式によって空白に見えているのであれば
=IF(C9="","",COUNTIF(C$9:C9,"?*"))
という数式で対応できると思います。
どうしてもVBAでやりたい!というコトであれば
Sub Sample1()
Dim lastRow As Long
lastRow = Cells(Rows.Count, "C").End(xlUp).Row
With Range(Cells(9, "A"), Cells(lastRow, "A"))
.Formula = "=IF(C9="""","""",COUNTA(C$9:C9))"
.Value = .Value
End With
End Sub
でもいけると思います。
※ C列に数式が入っている場合は
コード内の数式の行も変えます。m(_ _)m
tom04さん、早速回答ありがとうございました。
たくさんの方々に、色々な方法を教えていただき
勉強になります。
この方法でもやってみたいと思います。
No.5
- 回答日時:
こんなのでも行けるかも・・・。
Sub sample()
With Range("C9:C35").SpecialCells(xlCellTypeConstants, 23).Offset(, -2)
.Cells(1).Value = 1
.DataSeries Rowcol:=xlColumns, Type:=xlLinear, Step:=1
End With
End Sub
ママチャリさん、早速回答していただきありがとうございました。
色んな方法があって、素人には勉強になります。
この方法でもやってみます。
No.4
- 回答日時:
ちょっと違った方法で。
Sub megu()
Dim r As Range, rr As Range
Dim n As Long
n = 0
For Each r In Range("C9:C35").SpecialCells(xlCellTypeConstants).Areas
For Each rr In r
n = n + 1
rr.Offset(, -2).Value = n
Next
Next
End Sub
めぐみんさん
早速、回答していただきありがとうございました。
色んなやり方があって、素人には勉強になります。
お世話になりました。
No.2
- 回答日時:
こんにちは
入力する数字を、「i - 8」としているので、「行番号 - 8」となっていますね。
別に番号をカウントする変数(例えばn)を設けておけばよろしいかと思います。
Dim i As Long, n As Long
n = 1
For i = 9 To 35
If Range("C" & i).Value = "" Then
Range("A" & i).Value = ""
Else
Range("A" & i).Value = n
n = n + 1
End If
Next
でも、この程度であれば、A9セルに
=IF(C9="","",COUNT(A$8:A8)+1)
を入力して、下方にフィルコピーでもこと足りると思います。
(これなら、C列に追加入力があると自動的に附番されます)
※ 上式はA1:A8が空白であるという仮定で作成しています。そうでない場合は「+1」の部分の数値を調整することで対応できると思います。
fujillinさん、早速回答していただきありがとうございました。
ご指摘のようにこれまでは、数式を入力してやっていたのですが
事情があってマクロですることにしました。
A1:A8は空白でないので、「+1」の部分の数値を変えて
やってみます。
お世話になりました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) B列に文字がはいったらA列に数字が入るマクロードを完成させたい 4 2023/04/21 01:58
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
- Visual Basic(VBA) 稀に1円合いません? Sheet1から金額と個数を貼り付ける下記コードで、金額を切り上げるコードを何 3 2022/09/05 15:11
- Excel(エクセル) VBA 特定の列に入っているテキストをコピペ 2 2023/06/14 11:24
- Visual Basic(VBA) 動きっぱなしです。止め方とプロシージャの間違いを教えて下さい! 5 2022/08/15 23:08
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- Excel(エクセル) 日付で矢印マクロ 4 2023/07/25 16:47
- Visual Basic(VBA) 【VBA】写真の貼り付けコードがうまく機能しません。 5 2022/09/01 18:43
- Visual Basic(VBA) 前回ご教授いただいたコードに覚えたてのループ処理で品名りんごAから順に20回for nextでループ 7 2023/01/13 22:01
- Visual Basic(VBA) VBA 税率を判定表する方法を教えて下さい。 10 2022/03/28 11:21
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
【EXCEL】【VBA】空欄は飛ばして処理する方法を教えて下さい。
Excel(エクセル)
-
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
-
4
VBA 何かしら文字が入っていたら
Visual Basic(VBA)
-
5
セルに値が入っていた時の処理
Visual Basic(VBA)
-
6
EXCEL VBA セルに既に入力されている文字に文字を追加する
Excel(エクセル)
-
7
E列のセルに数値が入れば(空白でなければ)B列の同じ行のセルに色がつく
その他(Microsoft Office)
-
8
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
9
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
10
エクセルのエラーメッセージ「400」って?
Visual Basic(VBA)
-
11
別のシートから値を取得するとき
Visual Basic(VBA)
-
12
【Excel VBA】指定行以降をクリアするには?
Visual Basic(VBA)
-
13
Excel VBA 空白セルがあったらメッセージボックスで知らせたい
Visual Basic(VBA)
-
14
【vba】指定範囲の中に任意の文字があるときの条件分岐
Excel(エクセル)
-
15
worksheetFunctionクラスのVlookupプロパティを取得できません エラーへの対応
Visual Basic(VBA)
-
16
エクセルVBAで、条件に一致するセルへ移動
Excel(エクセル)
-
17
エクセルで空白以外のセルの値を取りたいのですが
その他(Microsoft Office)
-
18
空白セルをとばして転記
Visual Basic(VBA)
-
19
メッセージボックスに表示する文字を大きくしたい
Excel(エクセル)
-
20
エクセルVBA 4行飛ばしで転記するループ処理
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Vba TextBox1.ControlSourceに...
-
サブフォルダに格納されている...
-
VBA 別ブックからコピペしたい...
-
IF文、条件分岐の整理方法
-
Excel VBA 定義されたプロージ...
-
VBAコードのインデント表示
-
時間短縮のために、テキストフ...
-
【ExcelVBA】インデックスが有...
-
Outlookの「受信日時」「件名」...
-
Excel-VBAのmsgBox()の不思議
-
VBAの質問です、複数のテキスト...
-
重複確認
-
現在のブックを閉じないで、マ...
-
excelのVBAについて、以下のコ...
-
Excel VBA 選択範囲の罫線色の...
-
エクセルのマクロについて教え...
-
Excel 範囲指定スクショについ...
-
vba アクティブシートの名前変...
-
IEを使わないでhtmlテキストを...
-
Excel VBA マクロ あるフォルダ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBAなくなるの?
-
VBAでCOPYを繰り返すと、処理が...
-
vba 削除
-
プログラミング
-
Excelのマクロについて教えてく...
-
Excelのマクロについて教えてく...
-
エクセルのVBAコードについて教...
-
久しぶりのプログラミング
-
ユーザーフォームに別シートか...
-
エクセルVBAコードで教えて下さ...
-
VBA 別ブックからコピペしたい...
-
ExcelのVBAコードについて教え...
-
VBAコードについて教えてくださ...
-
vba アクティブシートの名前変...
-
Excelのマクロについて教えてく...
-
エクセルVBA
-
Geogebraの操作方法について
-
マクロの記録を使用したマクロ...
-
Excel(M365) Vlookup/セル反転(...
-
Excel 範囲指定スクショについ...
おすすめ情報