4
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

Excelをサクッと加工したい…ChatGPTにExcel VBAコードを聞いてみた!

Last updated at Posted at 2023-12-10

Excelの単純な加工ってめんどくさい…

Excelの行や列を消したり、追加したりする単純な加工ってめんどくさい:frowning2:
単発だったら仕方ないけど、毎月の作業だとなんかこの作業無意味やなと思ってしまいます…

先日UdemyでExcel VBAの超入門講座を受講し、これはめんどくさいと思っているExcel加工に使えるなと思いました。
↓↓↓受講したUdemy講座に関して書いたnote記事

また別日にChatGPTについて学び、細かくChatGPTに指示すれば必要なコードを一瞬で書いてくれることを知りました。

そこで今回はChatGPTにExcel加工のVBAコードを書いてもらうことにしたいと思います:relaxed:

さっそくChatGPTにコードを書いてもらう!

今回加工するのは、自社の経費データリストです。
なぜ今回このExcelを選んだかというと、今のところ一番加工する回数が多いからです!
年に28回…しかもめちゃくちゃ単純な加工…手始めにもってこいです!

普段このExcelでは、不要な行や列を削除した上で、VLOOKUP関数を入力する作業を行っています。
image.png

さっそくChatGPTにExcel加工のVBAコードを聞いてみます。
image.png
image.png
これはすぐにできちゃうパターンかと思いながら、書いてもらったコードをコピペして実行したところ…まさかの全消し!
image.png
おっと、これは一筋縄ではいかない様子です:scream:

ChatGPTとのやりとり

①不要行・不要列の削除

全部消えたとChatGPTに伝えコードを修正してもらいましたが、結果は同じ…
うーん、実行後のシートを見る限り、A列とB列はちゃんと消えているから多分『G列のセルの中身が「集計」となっている行も行ごと削除する』という部分の指示がよくなかったと推測し、ChatGPTに再度指示を出しました。
image.png
image.png
再度書いてもらったコードをコピペして実行したところ、ちゃんと指示したところだけ消えている!…と思ったらS列だけ消えていません。
2度S列が削除されていませんとChatGPTに伝えコードを修正してもらいましたが、またしても結果は同じ…
絶対何か私の指示にダメなところがあるはずとコードを見てたところ、
image.png
もしやA列、B列削除のあとにS列削除があるから、その時点でS列ではなくなっているから消えないのかも!と思い、ChatGPTに再度指示を出しました。
image.png
2列分マイナスした列を指定しました。
ただ、なぜか違うところ(「集計」となっている行の削除は元々G列を指定)も書き換えてきたので再度修正指示。
image.png
そしたら次は1つ前に指示したS列→Q列への修正をしれっと元に戻してきました。
完全にいたちごっこ…
image.png
image.png
これでようやく不要行、不要列の削除ができました:grin:

②VLOOKUP関数の追加

次にシートのD列(管理区分名称)を検索値として、「営業科目」という別シートからQ列に科目を表示させるVLOOKUP関数を追加したいと思います。
image.png
書いてもらったコードをコピペして実行したところ、なぜか途中でファイルを指定する画面になってしまいました…どうやら「営業科目」が同じファイル内の別シートということが伝わっていないようです。
image.png
うまく伝わり、無事VLOOKUP関数が追加されました:laughing:

最終的なExcel VBAのコード

Sub 削除コードとVLOOKUP()
    Dim ws As Worksheet
    Dim lastRow As Long
    Dim i As Long

    ' 対象のシートを指定
    Set ws = ThisWorkbook.Sheets("Sheet1")  ' "Sheet1" を自分のシートの名前に変更してください

    ' 最終行を取得
    lastRow = ws.Cells(ws.Rows.Count, "A").End(xlUp).Row

    ' G列が集計の行を削除
    For i = lastRow To 1 Step -1
        If ws.Cells(i, 7).Value = "集計" Then
            ws.Rows(i).Delete
        End If
    Next i

    ' 1~8行目、A列、B列、Q列の削除
    ws.Rows("1:8").Delete
    ws.Columns("A:B").Delete
    ws.Columns("Q:Q").Delete

    ' Q列1行目に"科目"を入力
    ws.Range("Q1").Value = "科目"

    ' VLOOKUPの公式をQ列2行目以降に追加
    lastRow = ws.Cells(ws.Rows.Count, "D").End(xlUp).Row

    For i = 2 To lastRow
        ws.Cells(i, 17).Formula = "=VLOOKUP(D" & i & ",営業科目!B:C,2,FALSE)"
    Next i

End Sub

今回できなかったこと

せっかくなので他のExcelの加工も挑戦してみようと思い、毎月加工している固定資産明細表もやってみることにしました。
Excelのセルの中の無数の余計なスペースが入っており、いつもテキストエディタにコピペし、正規表現を使用してスペースの置換をしています。
image.png
これをChatGPTにコードを書いてもらってExcel上でできるようにならないかと思ったのですが、うまくいかず…
image.png
image.png

そもそも元々の作業自体引き継いだ手順書通りやっているだけで、正直正規表現の意味もよく理解できていません。
それではChatGPTにうまく伝えられるはずありませんね…
これに関しては、今後の課題にしたいと思います!

最後に!

今回のExcel加工、自身の手作業でかかる時間を測定すると約2分。
年間28回作業が発生するので、年間の作業時間の削減は2分×28回=56分…:sweat_smile:
微々たる削減ですが、積み重ねだと思って今後も他にもできるものがないか考えたいなと思います!

今回すぐできちゃうかなと思いましたが、意外とChatGPTとのやりとりに苦戦…
人だとなんとなく理解してくれそうなことも、ChatGPT相手だとより細かく正確に伝える必要があるなと改めて思いました。

でも、Excel VBAのコードの知識がほぼ皆無な私でも、ChatGPTに聞くことでサクッとワンクリックでExcel加工できるようになる…これって本当にすごいですね!
ある程度Excel VBAがわかるようになったら、ざっくりChatGPTにコードを書いてもらって、細かいところは自分で修正とか応用も利きそうです!

今後も便利に使っていきたいと思います:smile:

4
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?