以下の2行の コードが分かりません
特にNが、特に定義されていないので、突然でてきた感じで
分かりません。iは1から2までと定義しています
本コードは、Sheet2で実行すると、下記の表の2行目の
A~d列までコピーされ、Sheet2のA1セルに貼付されます
答えは良いのですが、なぜ、そのような結果になるのかが分かりません
ご存じの方、教えて下さい
【分からないコード】
N = N + 1
.Range(.Cells(i, 1), .Cells(i, 4)).Copy Cells(N, 1)
【表】Sheet1
A B C D
1行 佐藤 一郎 1 1 1
2行 エクセル太郎 101 1 1
3行 鈴木 次郎 1 1 1
【コード】動きます
Sub Sample()
Dim i As Long
Dim N As Long
With Sheets("Sheet1")
For i = 1 To 3
If .Cells(i, 2) > 100 Then
N = N + 1
.Range(.Cells(i, 1), .Cells(i, 4)).Copy Cells(N, 1)
End If
Next i
End With
End Sub
No.2ベストアンサー
- 回答日時:
こんにちは
>N = N + 1
ループ部分を単純化して
N = 0 ' ←1行追加
For i = 1 To 3
・・・
N = N + 1
・・・
Next i
のようになっていれば、理解できますよね?
VBAの場合、
Dim N As Long
を宣言した時点で、N = 0 として初期値が設定される仕様になっています。
ですので、上記の
>N = 0 ' ←1行追加
を省略しても、同じ意味になります。
>.Range(.Cells(i, 1), .Cells(i, 4)).Copy Cells(N, 1)
With 構文内の記述なので、オブジェクトが省略されている場合は、指定されたオブジェクトとして解釈されます。
ご質問のセンテンスであれば、
Sheets("Sheet1").Range(Sheets("Sheet1").Cells(i, 1), Sheets("Sheet1").Cells(i, 4)).Copy Cells(N, 1)
と同じ意味になります。
いちいち記述すると長くなるので、Withで短縮表記できるようにしているものと思います。
以下、勉強になりました。分かりやすい解説、いつも
ありがとうございます
VBAの場合、
Dim N As Long
を宣言した時点で、N = 0 として初期値が設定される仕様になっています。
No.1
- 回答日時:
Nはいきなり現れた時点で 0 です。
Ifを通過して来た時に
N=N+1 → =0+1 → =1
で、N に 1 が格納されます。
Nはコピペ先の行数ですね。
コピペ開始位置を2行目にしたいのであれば、
DIMの宣言の次の行あたりにでも N=1 を書き入れておけば良いです。
For の1巡目で i=1
Sheets("Sheet1").Cells(1, 2) = 1
で >100 を満たさないのでIfを抜ける。
For の2巡目で i=2
Sheets("Sheet1").Cells(2, 2) = 101
で >100 を満たさすので、If Then の処理に入る。
冒頭に書いた通り、Nの初期値は 0 なので、
N = N + 1 → N=1
コピペ作業が実行される
Sheets("Sheet1").Range(.Cells(2, 1), .Cells(2, 4)) をコピーし
Cells(1, 1)へ貼り付け。
For の3巡目で i=3
Sheets("Sheet1").Cells(3, 2) = 1
で >100 を満たさないのでIfを抜ける。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
準・究極の選択
「年収1000万円で一生カレーライス」か 「年収180万円で毎日何でも食べ放題」 あなたはどちらを選びますか?
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
Excelの数式の効率化について
Excel(エクセル)
-
数字入力後他の文字等が表示される方法について
Excel(エクセル)
-
Excelで数値を時間数に変換する関数について
Excel(エクセル)
-
-
4
【マクロ】functionプロシージャの、変数について
Excel(エクセル)
-
5
自動入力で今月はMONTH(TODAY())で良いのですが、翌月はどのようにすれば良いでしょうか。
Excel(エクセル)
-
6
Excelの数値の小数点表示について質問です
Excel(エクセル)
-
7
Excelで特定の文字列が含まれているか確認したい
Excel(エクセル)
-
8
エクセルで数字の組み合わせを列記したい
Excel(エクセル)
-
9
【ExcelVBA】UTF-8(BOM無)でCSV保存するには?
Excel(エクセル)
-
10
【関数】スペースがいくつ入った後の文字列を取り出したい
Excel(エクセル)
-
11
職場の人から聞かれており、こんなことができるか教えて下さい。 vbaとかはできません。。 下記リスト
Excel(エクセル)
-
12
エクセルでバーコード作成し使用しているんですが、違うパソコンで同じエクセルファイルを使用したらバーコ
Excel(エクセル)
-
13
2列に入っているデータを1列で表示する関数について
Excel(エクセル)
-
14
Excelを無料で使うには? パソコン購入して、マイクロソフトに登録して そのままExcelがデスク
Excel(エクセル)
-
15
重複しない値を取り出したい
Excel(エクセル)
-
16
エクセルを使用して、円周率を表示させる方法
Excel(エクセル)
-
17
Excel 対象のセルに入力が無いとセルに入力できないようにしたい
Excel(エクセル)
-
18
Excelの時刻の不思議
Excel(エクセル)
-
19
西暦や和暦の表示をyyyymmdd表示へ変更をしたい
Excel(エクセル)
-
20
エクセルで上位バイトのセルと下位バイトのセルを1つのセルにして16進数を作る方法
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・歩いた自慢大会
- ・許せない心理テスト
- ・字面がカッコいい英単語
- ・これ何て呼びますか Part2
- ・人生で一番思い出に残ってる靴
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・初めて自分の家と他人の家が違う、と意識した時
- ・単二電池
- ・チョコミントアイス
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ギターで2弦2フレットと3弦2フ...
-
ギターのTAB譜の記号 N.C....
-
草刈の際に電源ケーブルを切断...
-
エレキギターでスピッツチェリー
-
VBAのフォーム上にTextBoxたく...
-
【マクロ】PasteSpecialメソッ...
-
VBA ダブルクリックするたびに...
-
ドライアーのコードから煙が出...
-
電気コードはなぜ絡まるのか
-
ドレファソのコード名
-
ODELICダウンライト 解除ボタン
-
コードを白く塗りたい
-
ベース 初心者 バンド キー
-
【HULFT】 utllist とutladmin
-
(ネタバレ注意!) 24 シーズン5...
-
輸入盤CDの見分け方
-
dim7コードはシックスなのにな...
-
ベンダーコードについて教えて...
-
DLookupがうまく出来ません
-
ギターのコードについて。
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ギターのTAB譜の記号 N.C....
-
VBA ダブルクリックするたびに...
-
マイクロソフト 一時使用コード...
-
マイナーの裏コードは存在する?
-
【マクロ】functionプロシージ...
-
【マクロ】Ifとwith ステートメ...
-
CODE関数から他の文字コードの...
-
草刈の際に電源ケーブルを切断...
-
ドライアーのコードから煙が出...
-
【マクロ】PasteSpecialメソッ...
-
Amazonギフト券で本名はバレま...
-
DLookupがうまく出来ません
-
ギターで2弦2フレットと3弦2フ...
-
Dadd11というコードについて
-
Em7onA 。GonB。 GonAのおさ...
-
あいみょんのマリーゴールドのM...
-
JOBコードってなんでしょうか?
-
コードを白く塗りたい
-
【HULFT】 utllist とutladmin
-
【EXCEL-VBA】PDFファイルを開...
おすすめ情報