data:image/s3,"s3://crabby-images/3e744/3e744d2b8ec7980dbe246a41f4b7d2cdaabf2df8" alt="見出し画像"
表の列を反転するChatGPTと一緒に作ったよ
この説明は、ChatGPTで作成しています。
このVBAプロシージャは、Excelの表(データ範囲)内の列を左右逆に並べ替えるためのものです。具体的には、表の内容を一旦配列に格納し、その配列を操作することで効率的に列を反転させています。
手順の概要
アクティブなシートの表範囲を特定する
最終行と最終列を自動的に取得して、表全体の範囲(データ部分+見出し)を決定します。表のデータを配列に格納する
配列を使うことで、表全体のデータをメモリ上に読み込み、高速に処理できます。配列内のデータを列ごとに反転する
1行ずつ処理し、最初の列と最後の列を入れ替える操作を繰り返します。この入れ替えは、左右の列が順番に入れ替わるように進みます。反転後の配列をシートに書き戻す
変更を配列からExcelのシートに反映します。画面の更新を再開する
コードの実行中に画面がちらつかないようにするため、一時的に画面更新をオフにしています。
実行結果の例
たとえば、Excelに表があり、列が「A列、B列、C列、D列」の順番だった場合、このプロシージャを実行すると、「D列、C列、B列、A列」の順番に変わります。
コードのポイント
画面更新の停止と再開
実行中の見た目の変化を抑えて、動作をスムーズにします。配列を使った高速処理
シートを直接操作するのではなく、一旦配列に取り込むことで、処理を効率化しています。列の反転の仕組み
配列の最初と最後の列を入れ替える方法で、データを左右反転します。
参考リンク
Sub 表の列を反転するChatGPTと一緒に作ったよ()
Application.ScreenUpdating = False
Dim ws As Worksheet
Dim lastRow As Long, lastCol As Long
Dim table As Range
Dim tableData As Variant
Dim i As Long, j As Long
' アクティブシートを設定
Set ws = ActiveSheet
' 最終行と最終列を取得
lastRow = ws.Cells(ws.Rows.count, 1).End(xlUp).row
lastCol = ws.Cells(1, ws.Columns.count).End(xlToLeft).Column
' テーブル範囲を設定(見出しを含む)
Set table = ws.Range(ws.Cells(1, 1), ws.Cells(lastRow, lastCol))
' テーブルを配列に格納
tableData = table.Value
' 配列の列を左右反転
For i = LBound(tableData, 1) To UBound(tableData, 1)
For j = LBound(tableData, 2) To UBound(tableData, 2) \ 2
Dim temp As Variant
temp = tableData(i, j)
tableData(i, j) = tableData(i, UBound(tableData, 2) - j + 1)
tableData(i, UBound(tableData, 2) - j + 1) = temp
Next j
Next i
' 配列を再びシートに反映
table.Value = tableData
Application.ScreenUpdating = True
End Sub
ハッシュタグ
#excel #できること #vba #プログラミング初心者 #列操作 #テーブル #配列操作 #左右反転 #表データ #初心者向けVBA #エクセル活用 #自動化 #業務効率化 #VBA基礎 #セル操作 #プロシージャ #コード解説 #エクセルマクロ #列反転
English Translation
Title: Flip Table Columns with ChatGPT
This explanation is created using ChatGPT.
This VBA procedure flips the columns of a table (data range) in Excel. It temporarily stores the table data in an array and manipulates the data within the array to reverse the column order efficiently.
Summary of Steps
Identify the table range on the active sheet
The last row and column are automatically detected to define the table range (including headers).Store the table data in an array
Using arrays allows fast in-memory data processing.Reverse the column order in the array
Each row is processed, swapping the first column with the last one, proceeding inward.Write the reversed data back to the sheet
Changes made in the array are reflected on the Excel sheet.Resume screen updates
Screen updating is temporarily disabled to prevent flickering during execution.
Execution Example
For instance, if a table has columns in the order "Column A, Column B, Column C, Column D," running this procedure will reverse them to "Column D, Column C, Column B, Column A."
Key Points in Code
Disabling and enabling screen updating
Prevents visual disturbances during execution.Using arrays for efficient processing
Data is temporarily stored in an array for quick manipulation.Logic for reversing columns
Swaps columns iteratively from the outermost to the center.
Reference Links
Hashtags
#excel #whatyoucando #vba #beginnersprogramming #columnmanipulation #tables #arrayoperations #columnflip #tabledata #vba4beginners #excelusecases #automation #workflowefficiency #basicvba #celloperations #procedure #codeexplained #excelmacros #columnreversal