【VBA】一次元配列を縦方向にシートに貼り付け【範囲をリサイズする】
作成日:2022-12-04
更新日:2025-10-03

一次元配列を
「縦一行」に
貼りたい
「縦一行」に
貼りたい
セル範囲をリサイズして一次元配列を貼り付ける
transposeして縦に貼り付ける
' Paste 1D array vertically into a worksheet cell
' 一次元配列をシート上に縦方向に貼り付ける
Public Sub PasteToCellResize1AryForY( _
ByVal ws As Worksheet, _
ByVal row As Long, _
ByVal col As Long, _
ByRef ary As Variant)
Dim rowCount As Long
' 要素数 = UBound - LBound + 1
rowCount = UBound(ary) - LBound(ary) + 1
' 縦方向に rowCount 行分貼り付け
ws.Cells(row, col).Resize(rowCount, 1).Value = WorksheetFunction.Transpose(ary)
End Sub
Transposeって?
Transpose
縦と横を入れ替える
小数データであれば WorksheetFunction.Transpose が使える
Microsoft. (n.d.). WorksheetFunction.Transpose method (Excel). https://learn.microsoft.com/en-us/office/vba/api/excel.worksheetfunction.transpose

ちなみに、
リサイズで、セル範囲の大きさを変えている
その他の貼り付け
横方向の場合
二次元配列の場合

同じ処理をPythonでも書いてみよう
2022-12-04
編集後記:
この記事の内容がベストではないかもしれません。
記事一覧
-

[VBA]画像として貼り付けCopyPicture 【VBA】セル範囲を画像としてコピーする|CopyPicture -

グラフ設定を変更する 【VBA】グラフ設定を動的に変更する -

[VBA]Nameでパス変更 【VBA】ブックのフルパスを変更する(ファイル名の変更も含む)|Name -

[VBA]CSVに書き出す 【VBA】CSVに配列の中身を書き出す|ADODB.Stream -

[VBA]Redim とRedim Preserve 【VBA】配列の要素数を決める|ReDim vs ReDim Preserve & Pythonとの違い -

[VBA]Merge1D Arrays 【VBA】一次元配列と一次元配列を結合する