ExcelマクロVBA練習問題解答 | 第30回.総合練習問題3回答 | Excelマクロ練習問題集、エクセルVBAの学習教材



最終更新日:2015-10-22

第30回.総合練習問題3回答

回答ページです、


以下の表で問題です、行の削除・挿入の問題です。



    

左の表から、偶数行を削除し、1行目に空行、A列に空列を挿入して下さい。



では、シンキングタイム


開始



・・
・・・
・・・・
・・・・・


はい、終了。


では、回答のマクロです。

Sub 練習1()
  Dim i As Long
  For i = Cells(Rows.Count, 1).End(xlUp).Row To 1 Step -2
    Rows(i).Delete
  Next i
  Rows(1).Insert
  Columns(1).Insert
End Sub


行削除を、下から行うのがミソです。


後は、一行置きなので、Step 2 になります。


もし、上からやろうとすると、ちょっとマクロが書きづらくなります。


こんな感じになります。

Sub 練習2()
  Dim i As Long
  i = 2
  Do While Cells(i, 1) <> ""
    Rows(i).Delete
    i = i + 1
  Loop
  Rows(1).Insert
  Columns(1).Insert
End Sub


最終行が、行削除で常に変わってしまうので、For〜NextではなくDo〜Loopで処理しています。


しかし、1行置きなのに、iのカウントアップが1づつである事は、少し理解しづらいです。


要は、行を削除した時点で、次行以降が上にシフトされるので、


そこをイメージして、マクロ作成できかだけなんですが。



行・列の削除・挿入は、下・右からやりましょう。





同じテーマ「ExcelマクロVBA練習問題解答」の記事

第36回.総合練習問題4回答
第43回.総合練習問題5回答
第50回.総合練習問題6回答
第67回.総合練習問題7回答
第78回.総合練習問題8回答
第81回.総合練習問題9回答
第86回.総合練習問題10回答

新着記事 ・・・新着記事一覧を見る

最後の空白(や指定文字)以降の文字を取り出す|エクセル関数超技(3月26日)
先頭の数値、最後の数値を取り出す|エクセル関数超技(3月26日)
Excelファイルを開かずにシート名をチェック|ExcelマクロVBAサンプル集(3月23日)
数式の参照しているセルを取得する|ExcelマクロVBAサンプル集(3月18日)
CSVの読み込み方法(改の改)|ExcelマクロVBAサンプル集(3月17日)
変数とプロシージャーの命名について|ExcelマクロVBA技術解説(2月12日)
ファイルの一覧取得・削除(File)|Google Apps Script入門(1月24日)
フォルダの一覧取得・作成・削除(Folder)|Google Apps Script入門(1月24日)
フォルダとファイルを扱う(DriveApp)|Google Apps Script入門(1月24日)
スプレッドシートが非常に遅い、高速化するには|Google Apps Script入門(1月17日)

アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|ExcelマクロVBA入門
2.RangeとCellsの使い方|ExcelマクロVBA入門
3.徹底解説(VLOOKUP,MATCH,INDEX,OFFSET)|エクセル関数超技
4.Range以外の指定方法(Cells,Rows,Columns)|ExcelマクロVBA入門
5.セルの参照範囲を可変にする(OFFSET,COUNTA,MATCH)|エクセル関数超技
6.セルのコピー&値の貼り付け(PasteSpecial)|ExcelマクロVBA入門
7.変数とデータ型(Dim)|ExcelマクロVBA入門
8.ひらがな⇔カタカナの変換|エクセル基本操作
9.CSVの読み込み方法|ExcelマクロVBAサンプル集
10.VBAのFindメソッドの使い方には注意が必要です|ExcelマクロVBA技術解説



  • >
  • >
  • >
  • 総合練習問題3回答

  • このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


    記述には細心の注意をしたつもりですが、
    間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
    なお、掲載のVBAコードは自己責任で使ってください。万一データ破損等の損害が発生しても責任は負いません。

    ↑ PAGE TOP