プロジェクト情報・進め方
- .NET Framework 4.6.1
- Visual C#
- ASP.NET Web アプリケーション
- MVC 5
- 認証なし
- Homecontroller の Index アクション、ビューを修正していく
- SMTP サーバには Hotmail を利用した。Google アカウントは2段階認証や、アプリケーションパスワードなど、面倒事が多いため。
【Excel VBA】Range.Value (2 次元配列) の行・列を操作するクラスのコード – oki2a24 にて RangeValue インスタンスに関数名を引数に渡してマップ処理をできるようにしてみました。けれども、支障があるくらい遅かったですの><。ですので結局マップで回す部分を取り出して、別の関数に渡してやり、結果を RangeValue インスタンスの元の場所に戻してやる、という方法を取りました。
別の方法として、ダックタイピングで関数をもつオブジェクトを RangeValue インスタンスに渡すのはどうかしら?と思いつきました。今回はその記録ですの♪
Public Sub Test() Dim newSheet As Worksheet: Set newSheet = ThisWorkbook.Sheets.Add Debug.Print newSheet.Rows.Count End Sub
On Error Resume Next
でエラー発生時もコードの実行を継続させる。UBound
関数を用いて次元を判定する。何種類もの表に対して、定期的に、同じ内容の編集を何度も繰り返し行う場合に役立つと存じます。同じ手作業を繰り返し行わなくて済むようになりますので、楽ができますの♪
一方で、一度しか行わないのでしたら、本投稿のコードを使う必要性はない、という場合も多いかと存じます。
Range(Cells(起点行, 起点列), Cells(RangeValue.RowCount, RangeValue.ColCount))
のように起点となる行番号・列番号を指定すれば自動的にサイズを調整して反映するので楽。